wedata-feature-engineering 0.1.5__py3-none-any.whl → 0.1.7__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- wedata/__init__.py +1 -1
- wedata/feature_store/client.py +113 -41
- wedata/feature_store/constants/constants.py +19 -0
- wedata/feature_store/entities/column_info.py +4 -4
- wedata/feature_store/entities/feature_lookup.py +5 -1
- wedata/feature_store/entities/feature_spec.py +46 -46
- wedata/feature_store/entities/feature_table.py +42 -99
- wedata/feature_store/entities/training_set.py +13 -12
- wedata/feature_store/feature_table_client/feature_table_client.py +86 -31
- wedata/feature_store/spark_client/spark_client.py +30 -56
- wedata/feature_store/training_set_client/training_set_client.py +209 -38
- wedata/feature_store/utils/common_utils.py +213 -3
- wedata/feature_store/utils/feature_lookup_utils.py +6 -6
- wedata/feature_store/utils/feature_spec_utils.py +6 -6
- wedata/feature_store/utils/feature_utils.py +5 -5
- wedata/feature_store/utils/on_demand_utils.py +107 -0
- wedata/feature_store/utils/schema_utils.py +1 -1
- wedata/feature_store/utils/signature_utils.py +205 -0
- wedata/feature_store/utils/training_set_utils.py +18 -19
- wedata/feature_store/utils/uc_utils.py +1 -1
- {wedata_feature_engineering-0.1.5.dist-info → wedata_feature_engineering-0.1.7.dist-info}/METADATA +1 -1
- wedata_feature_engineering-0.1.7.dist-info/RECORD +43 -0
- feature_store/__init__.py +0 -6
- feature_store/client.py +0 -169
- feature_store/constants/__init__.py +0 -0
- feature_store/constants/constants.py +0 -28
- feature_store/entities/__init__.py +0 -0
- feature_store/entities/column_info.py +0 -117
- feature_store/entities/data_type.py +0 -92
- feature_store/entities/environment_variables.py +0 -55
- feature_store/entities/feature.py +0 -53
- feature_store/entities/feature_column_info.py +0 -64
- feature_store/entities/feature_function.py +0 -55
- feature_store/entities/feature_lookup.py +0 -179
- feature_store/entities/feature_spec.py +0 -454
- feature_store/entities/feature_spec_constants.py +0 -25
- feature_store/entities/feature_table.py +0 -164
- feature_store/entities/feature_table_info.py +0 -40
- feature_store/entities/function_info.py +0 -184
- feature_store/entities/on_demand_column_info.py +0 -44
- feature_store/entities/source_data_column_info.py +0 -21
- feature_store/entities/training_set.py +0 -134
- feature_store/feature_table_client/__init__.py +0 -0
- feature_store/feature_table_client/feature_table_client.py +0 -313
- feature_store/spark_client/__init__.py +0 -0
- feature_store/spark_client/spark_client.py +0 -286
- feature_store/training_set_client/__init__.py +0 -0
- feature_store/training_set_client/training_set_client.py +0 -196
- feature_store/utils/__init__.py +0 -0
- feature_store/utils/common_utils.py +0 -96
- feature_store/utils/feature_lookup_utils.py +0 -570
- feature_store/utils/feature_spec_utils.py +0 -286
- feature_store/utils/feature_utils.py +0 -73
- feature_store/utils/schema_utils.py +0 -117
- feature_store/utils/topological_sort.py +0 -158
- feature_store/utils/training_set_utils.py +0 -580
- feature_store/utils/uc_utils.py +0 -281
- feature_store/utils/utils.py +0 -252
- feature_store/utils/validation_utils.py +0 -55
- wedata/feature_store/utils/utils.py +0 -252
- wedata_feature_engineering-0.1.5.dist-info/RECORD +0 -79
- {wedata_feature_engineering-0.1.5.dist-info → wedata_feature_engineering-0.1.7.dist-info}/WHEEL +0 -0
- {wedata_feature_engineering-0.1.5.dist-info → wedata_feature_engineering-0.1.7.dist-info}/top_level.txt +0 -0
@@ -1,252 +0,0 @@
|
|
1
|
-
import os
|
2
|
-
from datetime import datetime, timezone
|
3
|
-
from functools import wraps
|
4
|
-
from typing import Any, Dict, List, Optional
|
5
|
-
from urllib.parse import urlparse
|
6
|
-
|
7
|
-
import mlflow
|
8
|
-
from mlflow.exceptions import RestException
|
9
|
-
from mlflow.store.artifact.artifact_repository_registry import get_artifact_repository
|
10
|
-
from mlflow.utils import databricks_utils
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
def enable_if(condition):
|
15
|
-
"""
|
16
|
-
A decorator that conditionally enables a function based on a condition.
|
17
|
-
If the condition is not truthy, calling the function raises a NotImplementedError.
|
18
|
-
|
19
|
-
:param condition: A callable that returns a truthy or falsy value.
|
20
|
-
"""
|
21
|
-
|
22
|
-
def decorator(func):
|
23
|
-
@wraps(func)
|
24
|
-
def wrapper(*args, **kwargs):
|
25
|
-
if not condition():
|
26
|
-
raise NotImplementedError
|
27
|
-
return func(*args, **kwargs)
|
28
|
-
|
29
|
-
return wrapper
|
30
|
-
|
31
|
-
return decorator
|
32
|
-
|
33
|
-
|
34
|
-
def as_list(obj, default=None):
|
35
|
-
if not obj:
|
36
|
-
return default
|
37
|
-
elif isinstance(obj, list):
|
38
|
-
return obj
|
39
|
-
else:
|
40
|
-
return [obj]
|
41
|
-
|
42
|
-
|
43
|
-
def as_directory(path):
|
44
|
-
if path.endswith("/"):
|
45
|
-
return path
|
46
|
-
return f"{path}/"
|
47
|
-
|
48
|
-
|
49
|
-
def is_empty(target: str):
|
50
|
-
return target is None or len(target.strip()) == 0
|
51
|
-
|
52
|
-
|
53
|
-
class _NoDbutilsError(Exception):
|
54
|
-
pass
|
55
|
-
|
56
|
-
|
57
|
-
def _get_dbutils():
|
58
|
-
try:
|
59
|
-
import IPython
|
60
|
-
|
61
|
-
ip_shell = IPython.get_ipython()
|
62
|
-
if ip_shell is None:
|
63
|
-
raise _NoDbutilsError
|
64
|
-
return ip_shell.ns_table["user_global"]["dbutils"]
|
65
|
-
except ImportError:
|
66
|
-
raise _NoDbutilsError
|
67
|
-
except KeyError:
|
68
|
-
raise _NoDbutilsError
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
def utc_timestamp_ms_from_iso_datetime_string(date_string: str) -> int:
|
73
|
-
# Python uses seconds for its time granularity, so we multiply by 1000 to convert to milliseconds.
|
74
|
-
# The Feature Store backend returns timestamps in milliseconds, so this allows for direct comparisons.
|
75
|
-
dt = datetime.fromisoformat(date_string)
|
76
|
-
utc_dt = dt.replace(tzinfo=timezone.utc)
|
77
|
-
return 1000 * utc_dt.timestamp()
|
78
|
-
|
79
|
-
|
80
|
-
def pip_depependency_pinned_major_version(pip_package_name, major_version):
|
81
|
-
"""
|
82
|
-
Generate a pip dependency string that is pinned to a major version, for example: "databricks-feature-lookup==0.*"
|
83
|
-
"""
|
84
|
-
return f"{pip_package_name}=={major_version}.*"
|
85
|
-
|
86
|
-
|
87
|
-
def add_mlflow_pip_depependency(conda_env, pip_package_name):
|
88
|
-
"""
|
89
|
-
Add a new pip dependency to the conda environment taken from the raw MLflow model. This method should only be
|
90
|
-
called for conda environments created by MLflow rather than for generic conda environments, because it assumes
|
91
|
-
the conda environment already contains pip as a dependency. In the case of MLflow models, this is a safe
|
92
|
-
assumption because MLflow always needs to add "mlflow" to the conda environment's pip dependencies.
|
93
|
-
|
94
|
-
This is idempotent and will not add a pip package that is already present in the list of pip packages.
|
95
|
-
"""
|
96
|
-
if pip_package_name is None or len(pip_package_name) == 0:
|
97
|
-
raise ValueError(
|
98
|
-
"Unexpected input: missing or empty pip_package_name parameter"
|
99
|
-
)
|
100
|
-
|
101
|
-
found_pip_dependency = False
|
102
|
-
if conda_env is not None:
|
103
|
-
for dep in conda_env["dependencies"]:
|
104
|
-
if isinstance(dep, dict) and "pip" in dep:
|
105
|
-
found_pip_dependency = True
|
106
|
-
pip_deps = dep["pip"]
|
107
|
-
if pip_package_name not in pip_deps:
|
108
|
-
pip_deps.append(pip_package_name)
|
109
|
-
# Fail early rather than at model inference time
|
110
|
-
if "dependencies" in conda_env and not found_pip_dependency:
|
111
|
-
raise ValueError(
|
112
|
-
"Unexpected input: mlflow conda_env did not contain pip as a dependency"
|
113
|
-
)
|
114
|
-
|
115
|
-
|
116
|
-
def download_model_artifacts(model_uri, dir):
|
117
|
-
"""
|
118
|
-
Downloads model artifacts from model_uri to dir. Intended for use only with Feature Store packaged models.
|
119
|
-
|
120
|
-
:param model_uri: The location, in URI format, of a model. Must be either in the model registry
|
121
|
-
(``models:/<model_name>/<model_version>``, ``models:/<model_name>/<stage>``) or the MLflow
|
122
|
-
artifact store (``runs:/<mlflow_run_id>/run-relative/path/to/model``).
|
123
|
-
:param dir: Location to place downloaded model artifacts.
|
124
|
-
"""
|
125
|
-
if not is_artifact_uri(model_uri):
|
126
|
-
raise ValueError(
|
127
|
-
f"Invalid model URI '{model_uri}'."
|
128
|
-
f"Use ``models:/model_name>/<version_number>`` or "
|
129
|
-
f"``runs:/<mlflow_run_id>/run-relative/path/to/model``."
|
130
|
-
)
|
131
|
-
|
132
|
-
try:
|
133
|
-
repo = get_artifact_repository(model_uri)
|
134
|
-
except RestException as e:
|
135
|
-
raise ValueError(f"The model at '{model_uri}' does not exist.", e)
|
136
|
-
|
137
|
-
artifact_path = os.path.join(mlflow.pyfunc.DATA, MODEL_DATA_PATH_ROOT)
|
138
|
-
if len(repo.list_artifacts(artifact_path)) == 0:
|
139
|
-
raise ValueError(
|
140
|
-
f"No suitable model found at '{model_uri}'. Either no model exists in this "
|
141
|
-
f"artifact location or an existing model was not packaged with Feature Store metadata. "
|
142
|
-
f"Only models logged by FeatureStoreClient.log_model can be used in inference."
|
143
|
-
)
|
144
|
-
|
145
|
-
return repo.download_artifacts(artifact_path="", dst_path=dir)
|
146
|
-
|
147
|
-
|
148
|
-
def validate_params_non_empty(params: Dict[str, Any], expected_params: List[str]):
|
149
|
-
"""
|
150
|
-
Validate that none of the expected parameters are empty, otherwise raise a Value error
|
151
|
-
for the first encountered empty parameter.
|
152
|
-
|
153
|
-
Tested with the following param types:
|
154
|
-
|
155
|
-
- str
|
156
|
-
- Dict
|
157
|
-
- List
|
158
|
-
|
159
|
-
:param params: A dictionary of param names -> param values, for example as returned by locals()
|
160
|
-
:param expected_params: List of params to check as non_empty
|
161
|
-
"""
|
162
|
-
for expected_param in expected_params:
|
163
|
-
if expected_param not in params:
|
164
|
-
raise ValueError(
|
165
|
-
f'Internal error: expected parameter "{expected_param}" not found in params dictionary'
|
166
|
-
)
|
167
|
-
param_value = params[expected_param]
|
168
|
-
if not param_value:
|
169
|
-
raise ValueError(f'Parameter "{expected_param}" cannot be empty')
|
170
|
-
|
171
|
-
|
172
|
-
def is_in_databricks_job():
|
173
|
-
"""
|
174
|
-
Overrides the behavior of the mlflow databricks_utils.is_in_databricks_job() to account for the fact that
|
175
|
-
some jobs have job_id but no run_id, for example one-time job runs.
|
176
|
-
"""
|
177
|
-
try:
|
178
|
-
return databricks_utils.get_job_id() is not None
|
179
|
-
except Exception:
|
180
|
-
return False
|
181
|
-
|
182
|
-
|
183
|
-
def get_workspace_url() -> Optional[str]:
|
184
|
-
"""
|
185
|
-
Overrides the behavior of the mlflow.utils.databricks_utils.get_workspace_url(),
|
186
|
-
as get_workspace_url does not always return URLs with defined schemes.
|
187
|
-
|
188
|
-
TODO (ML-32050): Refactor this implementation to mlflow, and bump minimum required mlflow version.
|
189
|
-
"""
|
190
|
-
workspace_url = databricks_utils.get_workspace_url()
|
191
|
-
if workspace_url and not urlparse(workspace_url).scheme:
|
192
|
-
workspace_url = "https://" + workspace_url
|
193
|
-
return workspace_url
|
194
|
-
|
195
|
-
|
196
|
-
def is_in_databricks_env():
|
197
|
-
"""
|
198
|
-
Determine if we are running in a Databricks environment (DBR, MLR, DLT, DCS, Mlflow Projects, Run Cmd 1.2 API, etc)
|
199
|
-
|
200
|
-
If any invoked methods raise an exception, swallow the exception and return False out of an abundance of caution.
|
201
|
-
"""
|
202
|
-
try:
|
203
|
-
return (
|
204
|
-
is_in_databricks_job()
|
205
|
-
or databricks_utils.is_in_databricks_notebook()
|
206
|
-
or databricks_utils.is_in_databricks_runtime()
|
207
|
-
)
|
208
|
-
except Exception:
|
209
|
-
return False
|
210
|
-
|
211
|
-
|
212
|
-
def sanitize_identifier(identifier: str):
|
213
|
-
"""
|
214
|
-
Sanitize and wrap an identifier with backquotes. For example, "a`b" becomes "`a``b`".
|
215
|
-
Use this function to sanitize identifiers such as column names in SQL and PySpark.
|
216
|
-
"""
|
217
|
-
return f"`{identifier.replace('`', '``')}`"
|
218
|
-
|
219
|
-
|
220
|
-
def sanitize_identifiers(identifiers: List[str]):
|
221
|
-
"""
|
222
|
-
Sanitize and wrap the identifiers in a list with backquotes.
|
223
|
-
"""
|
224
|
-
return [sanitize_identifier(i) for i in identifiers]
|
225
|
-
|
226
|
-
|
227
|
-
def sanitize_multi_level_name(multi_level_name: str):
|
228
|
-
"""
|
229
|
-
Sanitize a multi-level name (such as an Unity Catalog table name) by sanitizing each segment
|
230
|
-
and joining the results. For example, "ca+t.fo`o.ba$r" becomes "`ca+t`.`fo``o`.`ba$r`".
|
231
|
-
"""
|
232
|
-
segments = multi_level_name.split(".")
|
233
|
-
return ".".join(sanitize_identifiers(segments))
|
234
|
-
|
235
|
-
|
236
|
-
def unsanitize_identifier(identifier: str):
|
237
|
-
"""
|
238
|
-
Unsanitize an identifier. Useful when we get a possibly sanitized identifier from Spark or
|
239
|
-
somewhere else, but we need an unsanitized one.
|
240
|
-
Note: This function does not check the correctness of the identifier passed in. e.g. `foo``
|
241
|
-
is not a valid sanitized identifier. When given such invalid input, this function returns
|
242
|
-
invalid output.
|
243
|
-
"""
|
244
|
-
if len(identifier) >= 2 and identifier[0] == "`" and identifier[-1] == "`":
|
245
|
-
return identifier[1:-1].replace("``", "`")
|
246
|
-
else:
|
247
|
-
return identifier
|
248
|
-
|
249
|
-
|
250
|
-
# strings containing \ or ' can break sql statements, so escape them.
|
251
|
-
def escape_sql_string(input_str: str) -> str:
|
252
|
-
return input_str.replace("\\", "\\\\").replace("'", "\\'")
|
@@ -1,79 +0,0 @@
|
|
1
|
-
feature_store/__init__.py,sha256=CP3YAMoy3pSTWRYzTza_CYBnGbTv_KzycVEBMQCeiD8,101
|
2
|
-
feature_store/client.py,sha256=FG1xK460rD859iSY4VA75XeYhqStJD8Wlr0sRxk25LI,5267
|
3
|
-
feature_store/constants/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
4
|
-
feature_store/constants/constants.py,sha256=exW3kiFLDyCmU9cYHFjcvIQhPWEpFtkogLXeB9Arfd8,827
|
5
|
-
feature_store/entities/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
6
|
-
feature_store/entities/column_info.py,sha256=WezowI46YHDym5ZlbhCJDqhKbVcjXjnjt7dQdy3XqYM,4164
|
7
|
-
feature_store/entities/data_type.py,sha256=VpHS6Fr3TphQQ8NbAcEnDJ-8eOZV6ivYuWxv3pAM2RM,3394
|
8
|
-
feature_store/entities/environment_variables.py,sha256=ZEFml5H9MQuzBKM074mUrFYu-Sga4Knmxqiwpke2WGc,1679
|
9
|
-
feature_store/entities/feature.py,sha256=wX8fTBlJq3GYdj9rrBDCY3kFgcVBBAiOOZdxEhnQkNQ,1241
|
10
|
-
feature_store/entities/feature_column_info.py,sha256=-TGxRafYUaNKe0YzHus2XbfRaVrMv7pcffMdbtTT4nA,2031
|
11
|
-
feature_store/entities/feature_function.py,sha256=R17INrCE-U_Uj9KLbFz69aYlOkTETTwQHMMo470F4lQ,1865
|
12
|
-
feature_store/entities/feature_lookup.py,sha256=zUDMdDIboitOffYRZlurf_O_4UeBPmE5YS0PyCS2Fqg,7912
|
13
|
-
feature_store/entities/feature_spec.py,sha256=F4MiKEyvKZSBh6Uv7V4vVLbamZ9fRClaC3HCrUeynDE,20079
|
14
|
-
feature_store/entities/feature_spec_constants.py,sha256=YWDBfRiNDe6fUJFUBo3V4WYg2xsljoPAE-ZejfFZCgM,785
|
15
|
-
feature_store/entities/feature_table.py,sha256=4ghopIvJcoIlyFiSEuTkOcDWn88c1Kt6q5LWM4BYEHI,6073
|
16
|
-
feature_store/entities/feature_table_info.py,sha256=2vUaVdW_jw1dRAlmJWvBRueuMeuqWu_NYB9SlxLI7Uw,1126
|
17
|
-
feature_store/entities/function_info.py,sha256=l0kmiq2R_QNfSMJ7y0xZohlMiemgYSr1dN5vzV8ijIs,7314
|
18
|
-
feature_store/entities/on_demand_column_info.py,sha256=Eh5ieaj1TxC7DG6ipBZzH2ZyY0bwkLrDOkuZjgYr4gY,1297
|
19
|
-
feature_store/entities/source_data_column_info.py,sha256=a9jQOJvehwDIrKPwsP6W9YRBSPNK2nZYypE6-p80CwA,542
|
20
|
-
feature_store/entities/training_set.py,sha256=9H2uGnUxTAsk93Om50QxRELbeFCocwGMze2VexPVJWI,5569
|
21
|
-
feature_store/feature_table_client/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
22
|
-
feature_store/feature_table_client/feature_table_client.py,sha256=uir33K7oigrSnjTT6VbNOp0Nb22-X3JHd1_92kWjrow,10754
|
23
|
-
feature_store/spark_client/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
24
|
-
feature_store/spark_client/spark_client.py,sha256=vd-NCE9IGC0Ygqr-QSVY0teuWsQSkq_BFV4Mn6xMMNU,11578
|
25
|
-
feature_store/training_set_client/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
26
|
-
feature_store/training_set_client/training_set_client.py,sha256=Aa80xVXVE1KBdgplL9qqR8ftD5A5r2pfBttAhmySrB0,6696
|
27
|
-
feature_store/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
28
|
-
feature_store/utils/common_utils.py,sha256=ck8pJYeN6vrcZmTrcnmIOOJWzYZaY3ZjvRSVme4tplo,3314
|
29
|
-
feature_store/utils/feature_lookup_utils.py,sha256=iILSP4AFHXrjNTuId6mT7wtMFAsZejyxThr_mZHPRF4,22330
|
30
|
-
feature_store/utils/feature_spec_utils.py,sha256=jeWzEhmkVW-bMRySMx_5grepHAlLquMhYxpbbiaJR-g,11582
|
31
|
-
feature_store/utils/feature_utils.py,sha256=8KhlkWax3KAi_xRnStVPlhCxeUHO08VW2fmT9jN8QUs,2761
|
32
|
-
feature_store/utils/schema_utils.py,sha256=8NhNUsF4Z6UtmzFeaVBnmb7xut0LqZepK3M27PSEpfE,4484
|
33
|
-
feature_store/utils/topological_sort.py,sha256=ebzKxmxeCLk9seB1zR0ASCGXsZsa-DjxJeTc4KUadtg,6475
|
34
|
-
feature_store/utils/training_set_utils.py,sha256=V5yW-XQ9in7gNOo4xsWy7txnSw_Z9Zxm4mV7MQmrWnk,22466
|
35
|
-
feature_store/utils/uc_utils.py,sha256=ets7YlrAtkhW9kKyYajDNo6iZasBIhFyxUT2MOyLuV8,10767
|
36
|
-
feature_store/utils/utils.py,sha256=T6dOUX3oOYRsbvXyTIElFZ20kNO92KMYPUCrqY5eomE,8953
|
37
|
-
feature_store/utils/validation_utils.py,sha256=FslvrNs3kstqvM6THScLOluEE6O9RWlDrD9xiihTzlw,1735
|
38
|
-
wedata/__init__.py,sha256=oXL7D4a-5Twx50aBoB2TqfwODH-UbJy9Ovw1uvfeMf8,101
|
39
|
-
wedata/feature_store/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
40
|
-
wedata/feature_store/client.py,sha256=FG1xK460rD859iSY4VA75XeYhqStJD8Wlr0sRxk25LI,5267
|
41
|
-
wedata/feature_store/constants/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
42
|
-
wedata/feature_store/constants/constants.py,sha256=exW3kiFLDyCmU9cYHFjcvIQhPWEpFtkogLXeB9Arfd8,827
|
43
|
-
wedata/feature_store/entities/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
44
|
-
wedata/feature_store/entities/column_info.py,sha256=WezowI46YHDym5ZlbhCJDqhKbVcjXjnjt7dQdy3XqYM,4164
|
45
|
-
wedata/feature_store/entities/data_type.py,sha256=VpHS6Fr3TphQQ8NbAcEnDJ-8eOZV6ivYuWxv3pAM2RM,3394
|
46
|
-
wedata/feature_store/entities/environment_variables.py,sha256=ZEFml5H9MQuzBKM074mUrFYu-Sga4Knmxqiwpke2WGc,1679
|
47
|
-
wedata/feature_store/entities/feature.py,sha256=wX8fTBlJq3GYdj9rrBDCY3kFgcVBBAiOOZdxEhnQkNQ,1241
|
48
|
-
wedata/feature_store/entities/feature_column_info.py,sha256=-TGxRafYUaNKe0YzHus2XbfRaVrMv7pcffMdbtTT4nA,2031
|
49
|
-
wedata/feature_store/entities/feature_function.py,sha256=R17INrCE-U_Uj9KLbFz69aYlOkTETTwQHMMo470F4lQ,1865
|
50
|
-
wedata/feature_store/entities/feature_lookup.py,sha256=zUDMdDIboitOffYRZlurf_O_4UeBPmE5YS0PyCS2Fqg,7912
|
51
|
-
wedata/feature_store/entities/feature_spec.py,sha256=F4MiKEyvKZSBh6Uv7V4vVLbamZ9fRClaC3HCrUeynDE,20079
|
52
|
-
wedata/feature_store/entities/feature_spec_constants.py,sha256=YWDBfRiNDe6fUJFUBo3V4WYg2xsljoPAE-ZejfFZCgM,785
|
53
|
-
wedata/feature_store/entities/feature_table.py,sha256=4ghopIvJcoIlyFiSEuTkOcDWn88c1Kt6q5LWM4BYEHI,6073
|
54
|
-
wedata/feature_store/entities/feature_table_info.py,sha256=2vUaVdW_jw1dRAlmJWvBRueuMeuqWu_NYB9SlxLI7Uw,1126
|
55
|
-
wedata/feature_store/entities/function_info.py,sha256=l0kmiq2R_QNfSMJ7y0xZohlMiemgYSr1dN5vzV8ijIs,7314
|
56
|
-
wedata/feature_store/entities/on_demand_column_info.py,sha256=Eh5ieaj1TxC7DG6ipBZzH2ZyY0bwkLrDOkuZjgYr4gY,1297
|
57
|
-
wedata/feature_store/entities/source_data_column_info.py,sha256=a9jQOJvehwDIrKPwsP6W9YRBSPNK2nZYypE6-p80CwA,542
|
58
|
-
wedata/feature_store/entities/training_set.py,sha256=9H2uGnUxTAsk93Om50QxRELbeFCocwGMze2VexPVJWI,5569
|
59
|
-
wedata/feature_store/feature_table_client/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
60
|
-
wedata/feature_store/feature_table_client/feature_table_client.py,sha256=uir33K7oigrSnjTT6VbNOp0Nb22-X3JHd1_92kWjrow,10754
|
61
|
-
wedata/feature_store/spark_client/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
62
|
-
wedata/feature_store/spark_client/spark_client.py,sha256=vd-NCE9IGC0Ygqr-QSVY0teuWsQSkq_BFV4Mn6xMMNU,11578
|
63
|
-
wedata/feature_store/training_set_client/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
64
|
-
wedata/feature_store/training_set_client/training_set_client.py,sha256=Aa80xVXVE1KBdgplL9qqR8ftD5A5r2pfBttAhmySrB0,6696
|
65
|
-
wedata/feature_store/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
66
|
-
wedata/feature_store/utils/common_utils.py,sha256=ck8pJYeN6vrcZmTrcnmIOOJWzYZaY3ZjvRSVme4tplo,3314
|
67
|
-
wedata/feature_store/utils/feature_lookup_utils.py,sha256=iILSP4AFHXrjNTuId6mT7wtMFAsZejyxThr_mZHPRF4,22330
|
68
|
-
wedata/feature_store/utils/feature_spec_utils.py,sha256=jeWzEhmkVW-bMRySMx_5grepHAlLquMhYxpbbiaJR-g,11582
|
69
|
-
wedata/feature_store/utils/feature_utils.py,sha256=8KhlkWax3KAi_xRnStVPlhCxeUHO08VW2fmT9jN8QUs,2761
|
70
|
-
wedata/feature_store/utils/schema_utils.py,sha256=8NhNUsF4Z6UtmzFeaVBnmb7xut0LqZepK3M27PSEpfE,4484
|
71
|
-
wedata/feature_store/utils/topological_sort.py,sha256=ebzKxmxeCLk9seB1zR0ASCGXsZsa-DjxJeTc4KUadtg,6475
|
72
|
-
wedata/feature_store/utils/training_set_utils.py,sha256=V5yW-XQ9in7gNOo4xsWy7txnSw_Z9Zxm4mV7MQmrWnk,22466
|
73
|
-
wedata/feature_store/utils/uc_utils.py,sha256=ets7YlrAtkhW9kKyYajDNo6iZasBIhFyxUT2MOyLuV8,10767
|
74
|
-
wedata/feature_store/utils/utils.py,sha256=T6dOUX3oOYRsbvXyTIElFZ20kNO92KMYPUCrqY5eomE,8953
|
75
|
-
wedata/feature_store/utils/validation_utils.py,sha256=FslvrNs3kstqvM6THScLOluEE6O9RWlDrD9xiihTzlw,1735
|
76
|
-
wedata_feature_engineering-0.1.5.dist-info/METADATA,sha256=2vR4aNUosgey5HA_HsyCV3XdgEi5xrEUD5gpavj2l7U,493
|
77
|
-
wedata_feature_engineering-0.1.5.dist-info/WHEEL,sha256=tZoeGjtWxWRfdplE7E3d45VPlLNQnvbKiYnx7gwAy8A,92
|
78
|
-
wedata_feature_engineering-0.1.5.dist-info/top_level.txt,sha256=Xa0v1rh__RvfVTVDirW5r5UBKg7ZO_iuTeXfp8MNo2A,7
|
79
|
-
wedata_feature_engineering-0.1.5.dist-info/RECORD,,
|
{wedata_feature_engineering-0.1.5.dist-info → wedata_feature_engineering-0.1.7.dist-info}/WHEEL
RENAMED
File without changes
|
File without changes
|