depot/third_party/nixpkgs/pkgs/development/python-modules/dataprep-ml/default.nix

83 lines
1.6 KiB
Nix

{
lib,
buildPythonPackage,
colorlog,
dataclasses-json,
fetchPypi,
nltk-data,
numpy,
pandas,
poetry-core,
pydantic,
pydateinfer,
python-dateutil,
pythonOlder,
scipy,
symlinkJoin,
type-infer,
}:
let
testNltkData = symlinkJoin {
name = "nltk-test-data";
paths = [
nltk-data.punkt
nltk-data.stopwords
];
};
in
buildPythonPackage rec {
pname = "dataprep-ml";
version = "24.5.1.2";
pyproject = true;
disabled = pythonOlder "3.8";
# using PyPI as github repo does not contain tags or release branches
src = fetchPypi {
pname = "dataprep_ml";
inherit version;
hash = "sha256-pZhHlNcQJLBww7ur2Z6Yb2IdbRsBtjzQAzfa4UzGKt4=";
};
pythonRelaxDeps = [ "pydantic" ];
nativeBuildInputs = [
poetry-core
];
propagatedBuildInputs = [
colorlog
dataclasses-json
numpy
pandas
pydantic
pydateinfer
python-dateutil
scipy
type-infer
];
# PyPI tarball has no tests
doCheck = false;
# Package import requires NLTK data to be downloaded
# It is the only way to set NLTK_DATA environment variable,
# so that it is available in pythonImportsCheck
env.NLTK_DATA = testNltkData;
pythonImportsCheck = [
"dataprep_ml"
"dataprep_ml.cleaners"
"dataprep_ml.helpers"
"dataprep_ml.imputers"
"dataprep_ml.insights"
"dataprep_ml.recommenders"
"dataprep_ml.splitters"
];
meta = with lib; {
description = "Data utilities for Machine Learning pipelines";
homepage = "https://github.com/mindsdb/dataprep_ml";
license = licenses.gpl3Only;
maintainers = with maintainers; [ mbalatsko ];
};
}