luxorasap 0.1.27__py3-none-any.whl → 0.1.29__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.
luxorasap/__init__.py CHANGED
@@ -13,7 +13,7 @@ from types import ModuleType
13
13
  try:
14
14
  __version__: str = metadata.version(__name__)
15
15
  except metadata.PackageNotFoundError: # editable install
16
- __version__ = "0.1.27"
16
+ __version__ = "0.1.29"
17
17
 
18
18
  # ─── Lazy loader ─────────────────────────────────────────────────
19
19
  def __getattr__(name: str) -> ModuleType:
@@ -2,6 +2,7 @@
2
2
 
3
3
  import pandas as pd
4
4
  import datetime as dt
5
+ import numpy as np
5
6
 
6
7
  from luxorasap.utils.storage import BlobParquetClient
7
8
  from luxorasap.utils.dataframe import prep_for_save, astype_str_inplace
@@ -28,6 +29,12 @@ def save_table(
28
29
 
29
30
  if 'Last_Updated' not in df.columns:
30
31
  df['Last_Updated'] = dt.datetime.now()
32
+ else:
33
+ # usando numpy, vamos substituir NaN ou 'nan' pela data e hora de agora
34
+ df["Last_Updated"] = np.where(((df["Last_Updated"].isna()) | (df["Last_Updated"] == 'nan')),
35
+ dt.datetime.now(),
36
+ df["Last_Updated"]
37
+ )
31
38
 
32
39
  if override == False:
33
40
  lq = LuxorQuery()
@@ -51,16 +58,24 @@ def incremental_load(
51
58
  index: bool = False,
52
59
  index_name: str = "index",
53
60
  normalize_columns: bool = True,
54
- directory: str = "enriched/parquet"
61
+ directory: str = "enriched/parquet",
62
+ unique_columns: list = None
55
63
  ):
56
64
  """Concatena novos dados aos existentes, cortando duplicados pela data."""
57
65
  df["Last_Updated"] = dt.datetime.now()
58
66
 
59
67
  if lq.table_exists(table_name):
60
68
  prev = lq.get_table(table_name)
61
- cutoff = df[increment_column].max()
62
- prev = prev.query(f"{increment_column} < @cutoff")
69
+ if increment_column is not None:
70
+ if increment_column not in df.columns:
71
+ raise ValueError(f"Coluna de incremento '{increment_column}' não existe no DataFrame.")
72
+ cutoff = df[increment_column].max()
73
+ prev = prev.query(f"{increment_column} < @cutoff")
63
74
  df = pd.concat([prev, df], ignore_index=True)
75
+ # remover duplicados
76
+
77
+ if unique_columns is not None:
78
+ df = df.drop_duplicates(subset=unique_columns, keep='last')
64
79
 
65
80
  save_table(
66
81
  table_name,
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: luxorasap
3
- Version: 0.1.27
3
+ Version: 0.1.29
4
4
  Summary: Toolbox da Luxor para ingestão, análise e automação de dados financeiros.
5
5
  Author-email: Luxor Group <backoffice@luxor.com.br>
6
6
  License: Proprietary – All rights reserved
@@ -1,4 +1,4 @@
1
- luxorasap/__init__.py,sha256=Lap_a2YVeAI84i3uDJettMmJb6Er5EKKvYcw9i4Fcuc,1356
1
+ luxorasap/__init__.py,sha256=9y_EbA4qhhTzW1QvanGb4GgyaclJC7tOZM4Su6NyD6Q,1356
2
2
  luxorasap/btgapi/__init__.py,sha256=QUlfb5oiBY6K1Q5x4-a-x2wECe1At5wc2962I5odOJk,620
3
3
  luxorasap/btgapi/auth.py,sha256=PvyCtbEyBO2B1CIeAlNXWugKW1OgiKfPcVzS6K5FBnQ,1872
4
4
  luxorasap/btgapi/reports.py,sha256=ZVEMLoJPXc0r3XjPJPMsKQN0zZd1Npd7umNpAj1bncs,8040
@@ -6,7 +6,7 @@ luxorasap/btgapi/trades.py,sha256=956HZ9BvN9C_VQvKTyBLN0x6ZygwVqBZN11F7OnNbDI,59
6
6
  luxorasap/datareader/__init__.py,sha256=41RAvbrQ4R6oj67S32CrKqolx0CJ2W8cbOF6g5Cqm2g,120
7
7
  luxorasap/datareader/core.py,sha256=mNXCHYTK-e-8cyfwwVAkHjgchqIg1WJa4rY1zXPCSR4,156040
8
8
  luxorasap/ingest/__init__.py,sha256=XhxDTN2ar-u6UCPhnxNU_to-nWiit-SpQ6cA_N9eMSs,795
9
- luxorasap/ingest/cloud/__init__.py,sha256=azo4zLS-kmV2ZZjePFB4CsibL4obbzHChC-Rn3Jp2Bc,2168
9
+ luxorasap/ingest/cloud/__init__.py,sha256=7yqEgeDxplkqYTzZNB0kfkSQ8PXF-77BXMW2DMYtJbU,2911
10
10
  luxorasap/ingest/legacy_local/dataloader.py,sha256=zKPhuiBSFwkuWN6d8g2s60KkbVk1R_1cGMCtQM9j-0c,11908
11
11
  luxorasap/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
12
12
  luxorasap/utils/dataframe/__init__.py,sha256=heKpmq58FmX35syzzwrHqlOWKYBkH2Z1jyqaQ_Vg-00,265
@@ -14,8 +14,8 @@ luxorasap/utils/dataframe/reader.py,sha256=Vzjdw-AeS1lnWEHQ8RZNh0kK93NWTp0NWVi_B
14
14
  luxorasap/utils/dataframe/transforms.py,sha256=OIvlTTcjFX6bUhuQp_syEp7ssm4sLzwvgsag6n2Wl3k,2438
15
15
  luxorasap/utils/storage/__init__.py,sha256=U3XRq94yzRp3kgBSUcRzs2tQgJ4o8h8a1ZzwiscA5XM,67
16
16
  luxorasap/utils/storage/blob.py,sha256=0QnwrUP-9vWYK8ffa6NqE7rV_t6RdScRM8GQnMxY_4w,3184
17
- luxorasap-0.1.27.dist-info/METADATA,sha256=okMLILpjx_OJjBP3R2Sf4MFE1wZofKmi230l2yG5__0,3804
18
- luxorasap-0.1.27.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
19
- luxorasap-0.1.27.dist-info/entry_points.txt,sha256=XFh-dOwUhlya9DmGvgookMI0ezyUJjcOvTIHDEYS44g,52
20
- luxorasap-0.1.27.dist-info/top_level.txt,sha256=9YOL6bUIpzY06XFBRkUW1e4rgB32Ds91fQPGwUEjxzU,10
21
- luxorasap-0.1.27.dist-info/RECORD,,
17
+ luxorasap-0.1.29.dist-info/METADATA,sha256=BmFqgAYTby5k8dCgFBTqntH1ylx3-rBTifNTdiJxqX4,3804
18
+ luxorasap-0.1.29.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
19
+ luxorasap-0.1.29.dist-info/entry_points.txt,sha256=XFh-dOwUhlya9DmGvgookMI0ezyUJjcOvTIHDEYS44g,52
20
+ luxorasap-0.1.29.dist-info/top_level.txt,sha256=9YOL6bUIpzY06XFBRkUW1e4rgB32Ds91fQPGwUEjxzU,10
21
+ luxorasap-0.1.29.dist-info/RECORD,,