luxorasap 0.1.14__tar.gz → 0.1.16__tar.gz

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.
Files changed (34) hide show
  1. {luxorasap-0.1.14 → luxorasap-0.1.16}/PKG-INFO +1 -1
  2. {luxorasap-0.1.14 → luxorasap-0.1.16}/pyproject.toml +2 -2
  3. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/__init__.py +1 -1
  4. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/datareader/core.py +10 -3
  5. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/utils/storage/blob.py +24 -6
  6. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap.egg-info/PKG-INFO +1 -1
  7. {luxorasap-0.1.14 → luxorasap-0.1.16}/README.md +0 -0
  8. {luxorasap-0.1.14 → luxorasap-0.1.16}/setup.cfg +0 -0
  9. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/btgapi/__init__.py +0 -0
  10. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/btgapi/auth.py +0 -0
  11. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/btgapi/reports.py +0 -0
  12. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/btgapi/trades.py +0 -0
  13. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/datareader/__init__.py +0 -0
  14. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/ingest/__init__.py +0 -0
  15. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/ingest/cloud/__init__.py +0 -0
  16. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/ingest/legacy_local/dataloader.py +0 -0
  17. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/utils/__init__.py +0 -0
  18. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/utils/dataframe/__init__.py +0 -0
  19. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/utils/dataframe/reader.py +0 -0
  20. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/utils/dataframe/transforms.py +0 -0
  21. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap/utils/storage/__init__.py +0 -0
  22. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap.egg-info/SOURCES.txt +0 -0
  23. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap.egg-info/dependency_links.txt +0 -0
  24. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap.egg-info/entry_points.txt +0 -0
  25. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap.egg-info/requires.txt +0 -0
  26. {luxorasap-0.1.14 → luxorasap-0.1.16}/src/luxorasap.egg-info/top_level.txt +0 -0
  27. {luxorasap-0.1.14 → luxorasap-0.1.16}/tests/test_btgapi_auth.py +0 -0
  28. {luxorasap-0.1.14 → luxorasap-0.1.16}/tests/test_btgapi_reports.py +0 -0
  29. {luxorasap-0.1.14 → luxorasap-0.1.16}/tests/test_btgapi_trades.py +0 -0
  30. {luxorasap-0.1.14 → luxorasap-0.1.16}/tests/test_datareader.py +0 -0
  31. {luxorasap-0.1.14 → luxorasap-0.1.16}/tests/test_ingest_cloud.py +0 -0
  32. {luxorasap-0.1.14 → luxorasap-0.1.16}/tests/test_ingest_legacy_local.py +0 -0
  33. {luxorasap-0.1.14 → luxorasap-0.1.16}/tests/test_utils_dataframe.py +0 -0
  34. {luxorasap-0.1.14 → luxorasap-0.1.16}/tests/test_utils_storage.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: luxorasap
3
- Version: 0.1.14
3
+ Version: 0.1.16
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
@@ -10,7 +10,7 @@ build-backend = "setuptools.build_meta"
10
10
  #############################
11
11
  [project]
12
12
  name = "luxorasap"
13
- version = "0.1.14"
13
+ version = "0.1.16"
14
14
  description = "Toolbox da Luxor para ingestão, análise e automação de dados financeiros."
15
15
  readme = "README.md"
16
16
  requires-python = ">=3.9"
@@ -78,7 +78,7 @@ exclude = ["tests*"]
78
78
  # bumpver (sem-ver)
79
79
  #############################
80
80
  [tool.bumpver]
81
- current_version = "0.1.14"
81
+ current_version = "0.1.16"
82
82
  version_pattern = "MAJOR.MINOR.PATCH"
83
83
 
84
84
  # regex explícito – obrigatório no bumpver 2024+
@@ -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.14"
16
+ __version__ = "0.1.16"
17
17
 
18
18
  # ─── Lazy loader ─────────────────────────────────────────────────
19
19
  def __getattr__(name: str) -> ModuleType:
@@ -297,9 +297,10 @@ class LuxorQuery:
297
297
  last_date_df["Last_Price"] = last_prices.values
298
298
 
299
299
  table = (pd.concat([table, last_date_df]).sort_values(by="Date")
300
- .set_index("Date").groupby("Asset")
301
- .apply(lambda g: g[~g.index.duplicated(keep="first")].resample("D").ffill()).reset_index(level=0, drop=True)
302
- .reset_index())
300
+ .set_index("Date").groupby("Asset")
301
+ .apply(lambda g: g[~g.index.duplicated(keep="first")].resample("D").ffill(),
302
+ include_groups=False).reset_index(level=0, drop=True)
303
+ .reset_index())
303
304
 
304
305
  self.price_tables_loaded[table_key] = table
305
306
 
@@ -648,6 +649,12 @@ class LuxorQuery:
648
649
  prices = prices.set_index("Date").groupby("Asset")\
649
650
  .resample("D").last().ffill()\
650
651
  .reset_index(level=0, drop=True).reset_index()
652
+ # Precisará ser substituido pela linha abaixo no futuro
653
+ # Porém ha perda de eficiencia, avaliar outras opções.
654
+ #prices = prices.set_index("Date").groupby("Asset", group_keys=False)\
655
+ # .apply(lambda g: g.resample("D").last().ffill().assign(Asset=g.name),
656
+ # include_groups=False).reset_index()
657
+
651
658
 
652
659
  if get_intraday_prices:
653
660
  prices = self.__hist_prices_intraday_extensor(prices)
@@ -4,6 +4,7 @@ from datetime import timezone
4
4
  import pandas as pd
5
5
  import pyarrow as pa, pyarrow.parquet as pq
6
6
  from azure.storage.blob import BlobServiceClient
7
+ import tempfile
7
8
 
8
9
  from ..dataframe import read_bytes
9
10
 
@@ -33,13 +34,30 @@ class BlobParquetClient:
33
34
  return None, False
34
35
 
35
36
 
36
- def write_df(self, df, blob_path: str):
37
- table = pa.Table.from_pandas(df)
38
- buf = io.BytesIO()
39
- pq.write_table(table, buf)
40
- buf.seek(0)
41
- self._blob(blob_path).upload_blob(buf, overwrite=True)
37
+ def write_df(self, df, blob_path: str, large_df: bool = False):
38
+ if not large_df:
39
+ table = pa.Table.from_pandas(df)
40
+ buf = io.BytesIO()
41
+ pq.write_table(table, buf)
42
+ buf.seek(0)
43
+ self._blob(blob_path).upload_blob(buf, overwrite=True)
42
44
 
45
+ else:
46
+ with tempfile.NamedTemporaryFile(delete=False, suffix=".parquet") as f:
47
+ writer = None
48
+ chunk_size = 100_000
49
+ for i in range(0, len(df), chunk_size):
50
+ chunk = pa.Table.from_pandas(df.iloc[i:i+chunk_size])
51
+ if writer is None:
52
+ writer = pq.ParquetWriter(f.name, chunk.schema)
53
+ writer.write_table(chunk)
54
+ writer.close()
55
+
56
+ with open(f.name, "rb") as f_read:
57
+ self._blob(blob_path).upload_blob(f_read, overwrite=True)
58
+
59
+ os.remove(f.name)
60
+
43
61
 
44
62
  def get_df_update_time(self, blob_path: str) -> float:
45
63
  try:
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: luxorasap
3
- Version: 0.1.14
3
+ Version: 0.1.16
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
File without changes
File without changes