luxorasap 0.2.12__tar.gz → 0.2.14__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 (39) hide show
  1. {luxorasap-0.2.12 → luxorasap-0.2.14}/PKG-INFO +1 -1
  2. {luxorasap-0.2.12 → luxorasap-0.2.14}/pyproject.toml +2 -2
  3. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/__init__.py +1 -1
  4. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/ingest/cloud/__init__.py +7 -0
  5. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/utils/storage/blob.py +45 -0
  6. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap.egg-info/PKG-INFO +1 -1
  7. {luxorasap-0.2.12 → luxorasap-0.2.14}/README.md +0 -0
  8. {luxorasap-0.2.12 → luxorasap-0.2.14}/setup.cfg +0 -0
  9. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/btgapi/__init__.py +0 -0
  10. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/btgapi/auth.py +0 -0
  11. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/btgapi/reports.py +0 -0
  12. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/btgapi/trades.py +0 -0
  13. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/datareader/__init__.py +0 -0
  14. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/datareader/core.py +0 -0
  15. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/ingest/__init__.py +0 -0
  16. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/ingest/legacy_local/dataloader.py +0 -0
  17. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/utils/__init__.py +0 -0
  18. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/utils/dataframe/__init__.py +0 -0
  19. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/utils/dataframe/reader.py +0 -0
  20. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/utils/dataframe/transforms.py +0 -0
  21. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/utils/storage/__init__.py +0 -0
  22. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/utils/storage/change_tracker.py +0 -0
  23. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/utils/tools/__init__.py +0 -0
  24. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap/utils/tools/excel.py +0 -0
  25. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap.egg-info/SOURCES.txt +0 -0
  26. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap.egg-info/dependency_links.txt +0 -0
  27. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap.egg-info/entry_points.txt +0 -0
  28. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap.egg-info/requires.txt +0 -0
  29. {luxorasap-0.2.12 → luxorasap-0.2.14}/src/luxorasap.egg-info/top_level.txt +0 -0
  30. {luxorasap-0.2.12 → luxorasap-0.2.14}/tests/test_btgapi_auth.py +0 -0
  31. {luxorasap-0.2.12 → luxorasap-0.2.14}/tests/test_btgapi_reports.py +0 -0
  32. {luxorasap-0.2.12 → luxorasap-0.2.14}/tests/test_btgapi_trades.py +0 -0
  33. {luxorasap-0.2.12 → luxorasap-0.2.14}/tests/test_datareader.py +0 -0
  34. {luxorasap-0.2.12 → luxorasap-0.2.14}/tests/test_ingest_cloud.py +0 -0
  35. {luxorasap-0.2.12 → luxorasap-0.2.14}/tests/test_ingest_legacy_local.py +0 -0
  36. {luxorasap-0.2.12 → luxorasap-0.2.14}/tests/test_utils_change_tracker.py +0 -0
  37. {luxorasap-0.2.12 → luxorasap-0.2.14}/tests/test_utils_dataframe.py +0 -0
  38. {luxorasap-0.2.12 → luxorasap-0.2.14}/tests/test_utils_storage.py +0 -0
  39. {luxorasap-0.2.12 → luxorasap-0.2.14}/tests/tests_utils_pickle_excel.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: luxorasap
3
- Version: 0.2.12
3
+ Version: 0.2.14
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.2.12"
13
+ version = "0.2.14"
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.2.12"
81
+ current_version = "0.2.14"
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.2.12"
16
+ __version__ = "0.2.14"
17
17
 
18
18
  # ─── Lazy loader ─────────────────────────────────────────────────
19
19
  def __getattr__(name: str) -> ModuleType:
@@ -60,6 +60,13 @@ def save_table(
60
60
  if index:
61
61
  df = df.reset_index().rename(columns={"index": index_name})
62
62
  _client_excel.write_excel(df, f"{directory}/{table_name}.xlsx")
63
+
64
+ elif format == 'excel_multiple_sheets':
65
+ global _client_excel
66
+ if _client_excel is None:
67
+ _client_excel = BlobExcelClient()
68
+ # df neste caso é um dicionário de DataFrames
69
+ _client_excel.write_excel_multiple_sheets(df, f"{directory}/{table_name}.xlsx")
63
70
 
64
71
  elif format == 'pickle':
65
72
  global _client_pickle
@@ -157,6 +157,51 @@ class BlobExcelClient:
157
157
  self._container.upload_blob(name=blob_name, data=buf, overwrite=True)
158
158
 
159
159
 
160
+ def write_excel_multiple_sheets(
161
+ self,
162
+ sheets: dict[str, pd.DataFrame],
163
+ blob_name: str,
164
+ *,
165
+ index: bool = False,
166
+ engine: str = "openpyxl",
167
+ **to_excel_kwargs,
168
+ ) -> None:
169
+ """
170
+ Salva várias abas de uma planilha Excel no blob, a partir de um dicionário
171
+ {nome_aba: DataFrame}.
172
+
173
+ Args:
174
+ sheets: Mapa de nome da aba -> DataFrame.
175
+ blob_name: Caminho/nome do blob (ex.: "reports/minha_planilha.xlsx").
176
+ index: Se True, escreve o índice dos DataFrames.
177
+ engine: Engine do pandas.ExcelWriter (default "openpyxl").
178
+ **to_excel_kwargs: repassado a `DataFrame.to_excel` (ex.: na_format, float_format).
179
+ """
180
+
181
+ def _sanitize_sheet_name(name: str) -> str:
182
+ # Excel limita a 31 chars e proíbe alguns caracteres
183
+ s = str(name)[:31]
184
+ for ch, repl in {":": "_", "/": "_", "\\": "_", "?": "_", "*": "_", "[": "(", "]": ")"}.items():
185
+ s = s.replace(ch, repl)
186
+ return s
187
+
188
+ if not isinstance(sheets, dict) or not sheets:
189
+ raise ValueError("`sheets` deve ser um dicionário não vazio 'aba': 'DataFrame'.")
190
+
191
+ buf = io.BytesIO()
192
+ with pd.ExcelWriter(buf, engine=engine) as writer:
193
+ for sheet_name, df in sheets.items():
194
+ sanitized = _sanitize_sheet_name(sheet_name)
195
+ if not isinstance(df, pd.DataFrame):
196
+ # tenta converter objetos "tabelares" em DataFrame
197
+ df = pd.DataFrame(df)
198
+ df.to_excel(writer, sheet_name=sanitized, index=index, **to_excel_kwargs)
199
+
200
+ buf.seek(0)
201
+ self._container.upload_blob(name=blob_name, data=buf, overwrite=True)
202
+
203
+
204
+
160
205
  def read_excel(self, blob_name: str, **kwargs) -> pd.DataFrame:
161
206
  """
162
207
  Lê um arquivo Excel do blob e retorna um DataFrame.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: luxorasap
3
- Version: 0.2.12
3
+ Version: 0.2.14
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