kensho-kfinance 2.7.0__py3-none-any.whl → 2.9.0__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.
Potentially problematic release.
This version of kensho-kfinance might be problematic. Click here for more details.
- {kensho_kfinance-2.7.0.dist-info → kensho_kfinance-2.9.0.dist-info}/METADATA +2 -2
- kensho_kfinance-2.9.0.dist-info/RECORD +70 -0
- kfinance/CHANGELOG.md +6 -0
- kfinance/decimal_with_unit.py +78 -0
- kfinance/fetch.py +15 -16
- kfinance/kfinance.py +108 -122
- kfinance/meta_classes.py +28 -27
- kfinance/models/business_relationship_models.py +26 -0
- kfinance/models/capitalization_models.py +90 -0
- kfinance/models/competitor_models.py +13 -0
- kfinance/models/currency_models.py +345 -0
- kfinance/models/date_and_period_models.py +48 -0
- kfinance/models/id_models.py +7 -0
- kfinance/models/industry_models.py +12 -0
- kfinance/{constants.py → models/line_item_models.py} +1 -165
- kfinance/models/permission_models.py +15 -0
- kfinance/models/price_models.py +70 -0
- kfinance/models/segment_models.py +8 -0
- kfinance/models/statement_models.py +9 -0
- kfinance/tests/test_batch_requests.py +61 -31
- kfinance/tests/test_client.py +1 -1
- kfinance/tests/test_decimal_with_unit.py +60 -0
- kfinance/tests/test_example_notebook.py +1 -0
- kfinance/tests/test_fetch.py +23 -12
- kfinance/tests/test_models/__init__.py +0 -0
- kfinance/tests/test_models/test_capitalization_models.py +83 -0
- kfinance/tests/test_models/test_price_models.py +58 -0
- kfinance/tests/test_objects.py +107 -57
- kfinance/tests/test_tools.py +35 -11
- kfinance/tool_calling/get_advisors_for_company_in_transaction_from_identifier.py +10 -7
- kfinance/tool_calling/get_business_relationship_from_identifier.py +2 -1
- kfinance/tool_calling/get_capitalization_from_identifier.py +4 -5
- kfinance/tool_calling/get_competitors_from_identifier.py +2 -1
- kfinance/tool_calling/get_cusip_from_ticker.py +1 -1
- kfinance/tool_calling/get_earnings.py +1 -1
- kfinance/tool_calling/get_financial_line_item_from_identifier.py +3 -1
- kfinance/tool_calling/get_financial_statement_from_identifier.py +3 -1
- kfinance/tool_calling/get_history_metadata_from_identifier.py +2 -1
- kfinance/tool_calling/get_info_from_identifier.py +1 -1
- kfinance/tool_calling/get_isin_from_ticker.py +1 -1
- kfinance/tool_calling/get_latest.py +2 -1
- kfinance/tool_calling/get_latest_earnings.py +1 -1
- kfinance/tool_calling/get_merger_info_from_transaction_id.py +6 -5
- kfinance/tool_calling/get_mergers_from_identifier.py +4 -1
- kfinance/tool_calling/get_n_quarters_ago.py +2 -1
- kfinance/tool_calling/get_next_earnings.py +1 -1
- kfinance/tool_calling/get_prices_from_identifier.py +4 -3
- kfinance/tool_calling/get_segments_from_identifier.py +3 -1
- kfinance/tool_calling/get_transcript.py +1 -1
- kfinance/tool_calling/resolve_identifier.py +1 -1
- kfinance/tool_calling/shared_models.py +1 -1
- kfinance/version.py +2 -2
- kensho_kfinance-2.7.0.dist-info/RECORD +0 -54
- {kensho_kfinance-2.7.0.dist-info → kensho_kfinance-2.9.0.dist-info}/WHEEL +0 -0
- {kensho_kfinance-2.7.0.dist-info → kensho_kfinance-2.9.0.dist-info}/licenses/AUTHORS.md +0 -0
- {kensho_kfinance-2.7.0.dist-info → kensho_kfinance-2.9.0.dist-info}/licenses/LICENSE +0 -0
- {kensho_kfinance-2.7.0.dist-info → kensho_kfinance-2.9.0.dist-info}/top_level.txt +0 -0
- /kfinance/{tests/scratch.py → models/__init__.py} +0 -0
kfinance/meta_classes.py
CHANGED
|
@@ -1,20 +1,19 @@
|
|
|
1
1
|
from abc import abstractmethod
|
|
2
2
|
from datetime import datetime
|
|
3
3
|
import logging
|
|
4
|
-
from typing import TYPE_CHECKING, Any, Callable,
|
|
4
|
+
from typing import TYPE_CHECKING, Any, Callable, Optional
|
|
5
5
|
|
|
6
6
|
from cachetools import LRUCache, cached
|
|
7
7
|
import numpy as np
|
|
8
8
|
import pandas as pd
|
|
9
9
|
|
|
10
|
-
from .constants import (
|
|
11
|
-
LINE_ITEMS,
|
|
12
|
-
BusinessRelationshipType,
|
|
13
|
-
CompetitorSource,
|
|
14
|
-
PeriodType,
|
|
15
|
-
SegmentType,
|
|
16
|
-
)
|
|
17
10
|
from .fetch import KFinanceApiClient
|
|
11
|
+
from .models.business_relationship_models import BusinessRelationshipType
|
|
12
|
+
from .models.capitalization_models import Capitalization
|
|
13
|
+
from .models.competitor_models import CompetitorSource
|
|
14
|
+
from .models.date_and_period_models import PeriodType
|
|
15
|
+
from .models.line_item_models import LINE_ITEMS
|
|
16
|
+
from .models.segment_models import SegmentType
|
|
18
17
|
from .pydantic_models import RelationshipResponse
|
|
19
18
|
|
|
20
19
|
|
|
@@ -262,73 +261,75 @@ class CompanyFunctionsMetaClass:
|
|
|
262
261
|
self,
|
|
263
262
|
start_date: Optional[str] = None,
|
|
264
263
|
end_date: Optional[str] = None,
|
|
265
|
-
) ->
|
|
264
|
+
) -> dict:
|
|
266
265
|
"""Retrieves market caps for a company between start and end date.
|
|
267
266
|
|
|
268
267
|
:param start_date: The start date in format "YYYY-MM-DD", default to None
|
|
269
268
|
:type start_date: str, optional
|
|
270
269
|
:param end_date: The end date in format "YYYY-MM-DD", default to None
|
|
271
270
|
:type end_date: str, optional
|
|
272
|
-
:return: A
|
|
273
|
-
:rtype:
|
|
271
|
+
:return: A dict with market_cap
|
|
272
|
+
:rtype: dict
|
|
274
273
|
"""
|
|
275
274
|
|
|
276
275
|
return self._fetch_market_cap_tev_or_shares_outstanding(
|
|
277
|
-
|
|
276
|
+
capitalization_to_extract=Capitalization.market_cap,
|
|
277
|
+
start_date=start_date,
|
|
278
|
+
end_date=end_date,
|
|
278
279
|
)
|
|
279
280
|
|
|
280
281
|
def tev(
|
|
281
282
|
self,
|
|
282
283
|
start_date: Optional[str] = None,
|
|
283
284
|
end_date: Optional[str] = None,
|
|
284
|
-
) ->
|
|
285
|
+
) -> dict:
|
|
285
286
|
"""Retrieves TEV (total enterprise value) for a company between start and end date.
|
|
286
287
|
|
|
287
288
|
:param start_date: The start date in format "YYYY-MM-DD", default to None
|
|
288
289
|
:type start_date: str, optional
|
|
289
290
|
:param end_date: The end date in format "YYYY-MM-DD", default to None
|
|
290
291
|
:type end_date: str, optional
|
|
291
|
-
:return: A
|
|
292
|
-
:rtype:
|
|
292
|
+
:return: A dict with TEV
|
|
293
|
+
:rtype: dict
|
|
293
294
|
"""
|
|
294
295
|
|
|
295
296
|
return self._fetch_market_cap_tev_or_shares_outstanding(
|
|
296
|
-
|
|
297
|
+
capitalization_to_extract=Capitalization.tev, start_date=start_date, end_date=end_date
|
|
297
298
|
)
|
|
298
299
|
|
|
299
300
|
def shares_outstanding(
|
|
300
301
|
self,
|
|
301
302
|
start_date: Optional[str] = None,
|
|
302
303
|
end_date: Optional[str] = None,
|
|
303
|
-
) ->
|
|
304
|
+
) -> dict:
|
|
304
305
|
"""Retrieves shares outstanding for a company between start and end date.
|
|
305
306
|
|
|
306
307
|
:param start_date: The start date in format "YYYY-MM-DD", default to None
|
|
307
308
|
:type start_date: str, optional
|
|
308
309
|
:param end_date: The end date in format "YYYY-MM-DD", default to None
|
|
309
310
|
:type end_date: str, optional
|
|
310
|
-
:return: A
|
|
311
|
-
:rtype:
|
|
311
|
+
:return: A dict with outstanding shares
|
|
312
|
+
:rtype: dict
|
|
312
313
|
"""
|
|
313
314
|
|
|
314
315
|
return self._fetch_market_cap_tev_or_shares_outstanding(
|
|
315
|
-
|
|
316
|
+
capitalization_to_extract=Capitalization.shares_outstanding,
|
|
317
|
+
start_date=start_date,
|
|
318
|
+
end_date=end_date,
|
|
316
319
|
)
|
|
317
320
|
|
|
318
321
|
def _fetch_market_cap_tev_or_shares_outstanding(
|
|
319
322
|
self,
|
|
320
|
-
|
|
323
|
+
capitalization_to_extract: Capitalization,
|
|
321
324
|
start_date: str | None,
|
|
322
325
|
end_date: str | None,
|
|
323
|
-
) ->
|
|
326
|
+
) -> dict:
|
|
324
327
|
"""Helper function to fetch market cap, TEV, and shares outstanding."""
|
|
325
328
|
|
|
326
|
-
|
|
327
|
-
self.
|
|
328
|
-
company_id=self.company_id, start_date=start_date, end_date=end_date
|
|
329
|
-
)["market_caps"]
|
|
329
|
+
capitalizations = self.kfinance_api_client.fetch_market_caps_tevs_and_shares_outstanding(
|
|
330
|
+
company_id=self.company_id, start_date=start_date, end_date=end_date
|
|
330
331
|
)
|
|
331
|
-
return
|
|
332
|
+
return capitalizations.jsonify_single_attribute(capitalization_to_extract)
|
|
332
333
|
|
|
333
334
|
def _segments(
|
|
334
335
|
self,
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
from strenum import StrEnum
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
class BusinessRelationshipType(StrEnum):
|
|
5
|
+
"""The type of business relationship"""
|
|
6
|
+
|
|
7
|
+
supplier = "supplier"
|
|
8
|
+
customer = "customer"
|
|
9
|
+
distributor = "distributor"
|
|
10
|
+
franchisor = "franchisor"
|
|
11
|
+
franchisee = "franchisee"
|
|
12
|
+
landlord = "landlord"
|
|
13
|
+
tenant = "tenant"
|
|
14
|
+
licensor = "licensor"
|
|
15
|
+
licensee = "licensee"
|
|
16
|
+
creditor = "creditor"
|
|
17
|
+
borrower = "borrower"
|
|
18
|
+
lessor = "lessor"
|
|
19
|
+
lessee = "lessee"
|
|
20
|
+
strategic_alliance = "strategic_alliance"
|
|
21
|
+
investor_relations_firm = "investor_relations_firm"
|
|
22
|
+
investor_relations_client = "investor_relations_client"
|
|
23
|
+
transfer_agent = "transfer_agent"
|
|
24
|
+
transfer_agent_client = "transfer_agent_client"
|
|
25
|
+
vendor = "vendor"
|
|
26
|
+
client_services = "client_services"
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
from copy import deepcopy
|
|
2
|
+
from datetime import date
|
|
3
|
+
from typing import Any
|
|
4
|
+
|
|
5
|
+
from pydantic import BaseModel, Field, model_validator
|
|
6
|
+
from strenum import StrEnum
|
|
7
|
+
|
|
8
|
+
from kfinance.decimal_with_unit import Money, Shares
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
class Capitalization(StrEnum):
|
|
12
|
+
"""The capitalization type"""
|
|
13
|
+
|
|
14
|
+
market_cap = "market_cap"
|
|
15
|
+
tev = "tev"
|
|
16
|
+
shares_outstanding = "shares_outstanding"
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
class DailyCapitalization(BaseModel):
|
|
20
|
+
"""DailyCapitalization represents market cap, TEV, and shares outstanding for a day"""
|
|
21
|
+
|
|
22
|
+
date: date
|
|
23
|
+
market_cap: Money
|
|
24
|
+
tev: Money
|
|
25
|
+
shares_outstanding: Shares
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
class Capitalizations(BaseModel):
|
|
29
|
+
"""Capitalizations represents market cap, TEV, and shares outstanding for a date range"""
|
|
30
|
+
|
|
31
|
+
capitalizations: list[DailyCapitalization] = Field(validation_alias="market_caps")
|
|
32
|
+
|
|
33
|
+
@model_validator(mode="before")
|
|
34
|
+
@classmethod
|
|
35
|
+
def inject_currency_into_data(cls, data: Any) -> Any:
|
|
36
|
+
"""Inject the currency into each market_cap and TEV.
|
|
37
|
+
|
|
38
|
+
The capitalization response only includes the currency as a top level element.
|
|
39
|
+
However, the capitalizations model expects the unit to be included with each market cap
|
|
40
|
+
and tev.
|
|
41
|
+
Before:
|
|
42
|
+
"market_caps": [
|
|
43
|
+
{
|
|
44
|
+
"date": "2024-06-24",
|
|
45
|
+
"market_cap": "139231113000.000000",
|
|
46
|
+
"tev": "153942113000.000000",
|
|
47
|
+
"shares_outstanding": 312900000
|
|
48
|
+
},
|
|
49
|
+
]
|
|
50
|
+
After:
|
|
51
|
+
"market_caps": [
|
|
52
|
+
{
|
|
53
|
+
"date": "2024-06-24",
|
|
54
|
+
"market_cap": {"value": "139231113000.000000", "unit": "USD"},
|
|
55
|
+
"tev": {"value": "153942113000.000000", "unit": "USD"},
|
|
56
|
+
"shares_outstanding": 312900000
|
|
57
|
+
},
|
|
58
|
+
|
|
59
|
+
Note: shares_outstanding does not need the unit injected because the Shares class
|
|
60
|
+
already has "Shares" encoded. However, currencies differ between companies,
|
|
61
|
+
so we need to inject that information.
|
|
62
|
+
"""
|
|
63
|
+
if isinstance(data, dict) and "currency" in data:
|
|
64
|
+
data = deepcopy(data)
|
|
65
|
+
currency = data["currency"]
|
|
66
|
+
for capitalization in data["market_caps"]:
|
|
67
|
+
for key in ["market_cap", "tev"]:
|
|
68
|
+
capitalization[key] = dict(unit=currency, value=capitalization[key])
|
|
69
|
+
return data
|
|
70
|
+
|
|
71
|
+
def jsonify_single_attribute(self, capitalization_to_extract: Capitalization) -> dict:
|
|
72
|
+
"""Return a json representation of a single attribute like "market_cap".
|
|
73
|
+
|
|
74
|
+
Example response:
|
|
75
|
+
{
|
|
76
|
+
"market_cap": [
|
|
77
|
+
{'2024-06-24': {'unit': 'USD', 'value': '139231113000.00'}},
|
|
78
|
+
{'2024-06-25': {'unit': 'USD', 'value': '140423262000.00'}}
|
|
79
|
+
]
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
"""
|
|
83
|
+
|
|
84
|
+
capitalizations = []
|
|
85
|
+
for capitalization in self.capitalizations:
|
|
86
|
+
attribute_val = getattr(capitalization, capitalization_to_extract.value)
|
|
87
|
+
capitalizations.append(
|
|
88
|
+
{capitalization.date.isoformat(): attribute_val.model_dump(mode="json")}
|
|
89
|
+
)
|
|
90
|
+
return {capitalization_to_extract: capitalizations}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
from strenum import StrEnum
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
class CompetitorSource(StrEnum):
|
|
5
|
+
"""The source type of the competitor information: 'filing' (from SEC filings), 'key_dev' (from key developments), 'contact' (from contact relationships), 'third_party' (from third-party sources), 'self_identified' (self-identified), 'named_by_competitor' (from competitor's perspective)."""
|
|
6
|
+
|
|
7
|
+
all = "all"
|
|
8
|
+
filing = "filing"
|
|
9
|
+
key_dev = "key_dev"
|
|
10
|
+
contact = "contact"
|
|
11
|
+
third_party = "third_party"
|
|
12
|
+
self_identified = "self_identified"
|
|
13
|
+
named_by_competitor = "named_by_competitor"
|
|
@@ -0,0 +1,345 @@
|
|
|
1
|
+
from dataclasses import dataclass
|
|
2
|
+
|
|
3
|
+
|
|
4
|
+
@dataclass
|
|
5
|
+
class Currency:
|
|
6
|
+
"""Follows ISO 4217"""
|
|
7
|
+
|
|
8
|
+
code: str
|
|
9
|
+
num: int
|
|
10
|
+
conventional_decimals: int
|
|
11
|
+
name: str
|
|
12
|
+
symbol: str | None
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
CURRENCIES = [
|
|
16
|
+
Currency(
|
|
17
|
+
code="AED",
|
|
18
|
+
num=784,
|
|
19
|
+
conventional_decimals=2,
|
|
20
|
+
name="United Arab Emirates dirham",
|
|
21
|
+
symbol=None,
|
|
22
|
+
),
|
|
23
|
+
Currency(code="AFN", num=971, conventional_decimals=2, name="Afghan afghani", symbol="\u060b"),
|
|
24
|
+
Currency(code="ALL", num=8, conventional_decimals=2, name="Albanian lek", symbol="Lek"),
|
|
25
|
+
Currency(code="AMD", num=51, conventional_decimals=2, name="Armenian dram", symbol="\u058f"),
|
|
26
|
+
Currency(code="AOA", num=973, conventional_decimals=2, name="Angolan kwanza", symbol="Kz"),
|
|
27
|
+
Currency(code="ARS", num=32, conventional_decimals=2, name="Argentine peso", symbol="Arg$"),
|
|
28
|
+
Currency(code="AUD", num=36, conventional_decimals=2, name="Australian dollar", symbol="A$"),
|
|
29
|
+
Currency(code="AWG", num=533, conventional_decimals=2, name="Aruban florin", symbol="\u0192"),
|
|
30
|
+
Currency(
|
|
31
|
+
code="AZN", num=944, conventional_decimals=2, name="Azerbaijani manat", symbol="\u20bc"
|
|
32
|
+
),
|
|
33
|
+
Currency(
|
|
34
|
+
code="BAM",
|
|
35
|
+
num=977,
|
|
36
|
+
conventional_decimals=2,
|
|
37
|
+
name="Bosnia and Herzegovina convertible mark",
|
|
38
|
+
symbol="KM",
|
|
39
|
+
),
|
|
40
|
+
Currency(code="BBD", num=52, conventional_decimals=2, name="Barbados dollar", symbol="Bds$"),
|
|
41
|
+
Currency(code="BDT", num=50, conventional_decimals=2, name="Bangladeshi taka", symbol="\u09f3"),
|
|
42
|
+
Currency(code="BGN", num=975, conventional_decimals=2, name="Bulgarian lev", symbol="lev"),
|
|
43
|
+
Currency(code="BHD", num=48, conventional_decimals=3, name="Bahraini dinar", symbol="BD"),
|
|
44
|
+
Currency(code="BIF", num=108, conventional_decimals=0, name="Burundian franc", symbol="FBu"),
|
|
45
|
+
Currency(code="BMD", num=60, conventional_decimals=2, name="Bermudian dollar", symbol="Ber$"),
|
|
46
|
+
Currency(code="BND", num=96, conventional_decimals=2, name="Brunei dollar", symbol="B$"),
|
|
47
|
+
Currency(code="BOB", num=68, conventional_decimals=2, name="Boliviano", symbol="Bs"),
|
|
48
|
+
Currency(
|
|
49
|
+
code="BOV",
|
|
50
|
+
num=984,
|
|
51
|
+
conventional_decimals=2,
|
|
52
|
+
name="Bolivian Mvdol (funds code),",
|
|
53
|
+
symbol=None,
|
|
54
|
+
),
|
|
55
|
+
Currency(code="BRL", num=986, conventional_decimals=2, name="Brazilian real", symbol="R$"),
|
|
56
|
+
Currency(code="BSD", num=44, conventional_decimals=2, name="Bahamian dollar", symbol="B$"),
|
|
57
|
+
Currency(code="BTN", num=64, conventional_decimals=2, name="Bhutanese ngultrum", symbol="Nu"),
|
|
58
|
+
Currency(code="BWP", num=72, conventional_decimals=2, name="Botswana pula", symbol="P"),
|
|
59
|
+
Currency(code="BYN", num=933, conventional_decimals=2, name="Belarusian ruble", symbol="R"),
|
|
60
|
+
Currency(code="BZD", num=84, conventional_decimals=2, name="Belize dollar", symbol="BZ$"),
|
|
61
|
+
Currency(code="CAD", num=124, conventional_decimals=2, name="Canadian dollar", symbol="C$"),
|
|
62
|
+
Currency(code="CDF", num=976, conventional_decimals=2, name="Congolese franc", symbol="FC"),
|
|
63
|
+
Currency(code="CHE", num=947, conventional_decimals=2, name="WIR franc", symbol=None),
|
|
64
|
+
Currency(code="CHF", num=756, conventional_decimals=2, name="Swiss franc", symbol="SFr"),
|
|
65
|
+
Currency(code="CHW", num=948, conventional_decimals=2, name="WIR franc", symbol=None),
|
|
66
|
+
Currency(
|
|
67
|
+
code="CLF",
|
|
68
|
+
num=990,
|
|
69
|
+
conventional_decimals=4,
|
|
70
|
+
name="Unidad de Fomento (funds code),",
|
|
71
|
+
symbol=None,
|
|
72
|
+
),
|
|
73
|
+
Currency(code="CLP", num=152, conventional_decimals=0, name="Chilean peso", symbol="Ch$"),
|
|
74
|
+
Currency(code="CNY", num=156, conventional_decimals=2, name="Renminbi", symbol="CN\u00a5"),
|
|
75
|
+
Currency(code="COP", num=170, conventional_decimals=2, name="Colombian peso", symbol="Col$"),
|
|
76
|
+
Currency(
|
|
77
|
+
code="COU",
|
|
78
|
+
num=970,
|
|
79
|
+
conventional_decimals=2,
|
|
80
|
+
name="Unidad de Valor Real (UVR), (funds code),",
|
|
81
|
+
symbol=None,
|
|
82
|
+
),
|
|
83
|
+
Currency(
|
|
84
|
+
code="CRC", num=188, conventional_decimals=2, name="Costa Rican colon", symbol="\u20a1"
|
|
85
|
+
),
|
|
86
|
+
Currency(code="CUP", num=192, conventional_decimals=2, name="Cuban peso", symbol="Cu$"),
|
|
87
|
+
Currency(code="CVE", num=132, conventional_decimals=2, name="Cape Verdean escudo", symbol=None),
|
|
88
|
+
Currency(code="CZK", num=203, conventional_decimals=2, name="Czech koruna", symbol="K\u010d"),
|
|
89
|
+
Currency(code="DJF", num=262, conventional_decimals=0, name="Djiboutian franc", symbol="DF"),
|
|
90
|
+
Currency(code="DKK", num=208, conventional_decimals=2, name="Danish krone", symbol="kr"),
|
|
91
|
+
Currency(code="DOP", num=214, conventional_decimals=2, name="Dominican peso", symbol="RD$"),
|
|
92
|
+
Currency(code="DZD", num=12, conventional_decimals=2, name="Algerian dinar", symbol="DA"),
|
|
93
|
+
Currency(code="EGP", num=818, conventional_decimals=2, name="Egyptian pound", symbol="\u00a3E"),
|
|
94
|
+
Currency(code="ERN", num=232, conventional_decimals=2, name="Eritrean nakfa", symbol="Nfk"),
|
|
95
|
+
Currency(code="ETB", num=230, conventional_decimals=2, name="Ethiopian birr", symbol="Br"),
|
|
96
|
+
Currency(code="EUR", num=978, conventional_decimals=2, name="Euro", symbol="\u20ac"),
|
|
97
|
+
Currency(code="FJD", num=242, conventional_decimals=2, name="Fiji dollar", symbol="FJ$"),
|
|
98
|
+
Currency(
|
|
99
|
+
code="FKP", num=238, conventional_decimals=2, name="Falkland Islands pound", symbol="\u00a3"
|
|
100
|
+
),
|
|
101
|
+
Currency(code="GBP", num=826, conventional_decimals=2, name="Pound sterling", symbol="\u00a3"),
|
|
102
|
+
Currency(code="GEL", num=981, conventional_decimals=2, name="Georgian lari", symbol="\u20be"),
|
|
103
|
+
Currency(code="GHS", num=936, conventional_decimals=2, name="Ghanaian cedi", symbol="\u20bf"),
|
|
104
|
+
Currency(code="GIP", num=292, conventional_decimals=2, name="Gibraltar pound", symbol="\u00a3"),
|
|
105
|
+
Currency(code="GMD", num=270, conventional_decimals=2, name="Gambian dalasi", symbol="D"),
|
|
106
|
+
Currency(code="GNF", num=324, conventional_decimals=0, name="Guinean franc", symbol="FG"),
|
|
107
|
+
Currency(code="GTQ", num=320, conventional_decimals=2, name="Guatemalan quetzal", symbol="Q"),
|
|
108
|
+
Currency(code="GYD", num=328, conventional_decimals=2, name="Guyanese dollar", symbol="G$"),
|
|
109
|
+
Currency(code="HKD", num=344, conventional_decimals=2, name="Hong Kong dollar", symbol="HK$"),
|
|
110
|
+
Currency(code="HNL", num=340, conventional_decimals=2, name="Honduran lempira", symbol="L"),
|
|
111
|
+
Currency(code="HTG", num=332, conventional_decimals=2, name="Haitian gourde", symbol="G"),
|
|
112
|
+
Currency(code="HUF", num=348, conventional_decimals=2, name="Hungarian forint", symbol="Ft"),
|
|
113
|
+
Currency(code="IDR", num=360, conventional_decimals=2, name="Indonesian rupiah", symbol="Rp"),
|
|
114
|
+
Currency(
|
|
115
|
+
code="ILS", num=376, conventional_decimals=2, name="Israeli new shekel", symbol="\u20aa"
|
|
116
|
+
),
|
|
117
|
+
Currency(code="INR", num=356, conventional_decimals=2, name="Indian rupee", symbol="\u20b9"),
|
|
118
|
+
Currency(code="IQD", num=368, conventional_decimals=3, name="Iraqi dinar", symbol="ID"),
|
|
119
|
+
Currency(code="IRR", num=364, conventional_decimals=2, name="Iranian rial", symbol="\ufdfc"),
|
|
120
|
+
Currency(code="ISK", num=352, conventional_decimals=0, name="Icelandic króna", symbol="kr"),
|
|
121
|
+
Currency(code="JMD", num=388, conventional_decimals=2, name="Jamaican dollar", symbol="J$"),
|
|
122
|
+
Currency(code="JOD", num=400, conventional_decimals=3, name="Jordanian dinar", symbol="JD"),
|
|
123
|
+
Currency(code="JPY", num=392, conventional_decimals=0, name="Japanese yen", symbol="\u00a5"),
|
|
124
|
+
Currency(code="KES", num=404, conventional_decimals=2, name="Kenyan shilling", symbol="KSh"),
|
|
125
|
+
Currency(code="KGS", num=417, conventional_decimals=2, name="Kyrgyzstani som", symbol="\u20c0"),
|
|
126
|
+
Currency(code="KHR", num=116, conventional_decimals=2, name="Cambodian riel", symbol="\u17db"),
|
|
127
|
+
Currency(code="KMF", num=174, conventional_decimals=0, name="Comoro franc", symbol="FC"),
|
|
128
|
+
Currency(
|
|
129
|
+
code="KPW", num=408, conventional_decimals=2, name="North Korean won", symbol="\u20a9"
|
|
130
|
+
),
|
|
131
|
+
Currency(
|
|
132
|
+
code="KRW", num=410, conventional_decimals=0, name="South Korean won", symbol="\u20a9"
|
|
133
|
+
),
|
|
134
|
+
Currency(code="KWD", num=414, conventional_decimals=3, name="Kuwaiti dinar", symbol="KD"),
|
|
135
|
+
Currency(
|
|
136
|
+
code="KYD", num=136, conventional_decimals=2, name="Cayman Islands dollar", symbol="CI$"
|
|
137
|
+
),
|
|
138
|
+
Currency(
|
|
139
|
+
code="KZT", num=398, conventional_decimals=2, name="Kazakhstani tenge", symbol="\u20b8"
|
|
140
|
+
),
|
|
141
|
+
Currency(code="LAK", num=418, conventional_decimals=2, name="Lao kip", symbol="\u20ad "),
|
|
142
|
+
Currency(code="LBP", num=422, conventional_decimals=2, name="Lebanese pound", symbol="LL"),
|
|
143
|
+
Currency(
|
|
144
|
+
code="LKR", num=144, conventional_decimals=2, name="Sri Lankan rupee", symbol="\u20a8"
|
|
145
|
+
),
|
|
146
|
+
Currency(code="LRD", num=430, conventional_decimals=2, name="Liberian dollar", symbol="L$"),
|
|
147
|
+
Currency(code="LSL", num=426, conventional_decimals=2, name="Lesotho loti", symbol="L"),
|
|
148
|
+
Currency(code="LYD", num=434, conventional_decimals=3, name="Libyan dinar", symbol="LD"),
|
|
149
|
+
Currency(code="MAD", num=504, conventional_decimals=2, name="Moroccan dirham", symbol="Dh"),
|
|
150
|
+
Currency(code="MDL", num=498, conventional_decimals=2, name="Moldovan leu", symbol="L"),
|
|
151
|
+
Currency(code="MGA", num=969, conventional_decimals=2, name="Malagasy ariary", symbol="Ar"),
|
|
152
|
+
Currency(code="MKD", num=807, conventional_decimals=2, name="Macedonian denar", symbol="DEN"),
|
|
153
|
+
Currency(code="MMK", num=104, conventional_decimals=2, name="Myanmar kyat", symbol="K"),
|
|
154
|
+
Currency(
|
|
155
|
+
code="MNT", num=496, conventional_decimals=2, name="Mongolian tögrög", symbol="\u20ae"
|
|
156
|
+
),
|
|
157
|
+
Currency(code="MOP", num=446, conventional_decimals=2, name="Macanese pataca", symbol="$"),
|
|
158
|
+
Currency(code="MRU", num=929, conventional_decimals=2, name="Mauritanian ouguiya", symbol="UM"),
|
|
159
|
+
Currency(code="MUR", num=480, conventional_decimals=2, name="Mauritian rupee", symbol="\u20a8"),
|
|
160
|
+
Currency(code="MVR", num=462, conventional_decimals=2, name="Maldivian rufiyaa", symbol="Rf"),
|
|
161
|
+
Currency(code="MWK", num=454, conventional_decimals=2, name="Malawian kwacha", symbol="MK"),
|
|
162
|
+
Currency(code="MXN", num=484, conventional_decimals=2, name="Mexican peso", symbol="Mex$"),
|
|
163
|
+
Currency(
|
|
164
|
+
code="MXV",
|
|
165
|
+
num=979,
|
|
166
|
+
conventional_decimals=2,
|
|
167
|
+
name="Mexican Unidad de Inversion (UDI), (funds code),",
|
|
168
|
+
symbol=None,
|
|
169
|
+
),
|
|
170
|
+
Currency(code="MYR", num=458, conventional_decimals=2, name="Malaysian ringgit", symbol="RM"),
|
|
171
|
+
Currency(code="MZN", num=943, conventional_decimals=2, name="Mozambican metical", symbol="Mt"),
|
|
172
|
+
Currency(code="NAD", num=516, conventional_decimals=2, name="Namibian dollar", symbol="N$"),
|
|
173
|
+
Currency(code="NGN", num=566, conventional_decimals=2, name="Nigerian naira", symbol="\u20a6"),
|
|
174
|
+
Currency(code="NIO", num=558, conventional_decimals=2, name="Nicaraguan córdoba", symbol="C$"),
|
|
175
|
+
Currency(code="NOK", num=578, conventional_decimals=2, name="Norwegian krone", symbol="kr"),
|
|
176
|
+
Currency(code="NPR", num=524, conventional_decimals=2, name="Nepalese rupee", symbol="\u20b9"),
|
|
177
|
+
Currency(code="NZD", num=554, conventional_decimals=2, name="New Zealand dollar", symbol="$NZ"),
|
|
178
|
+
Currency(code="OMR", num=512, conventional_decimals=3, name="Omani rial", symbol="RO"),
|
|
179
|
+
Currency(code="PAB", num=590, conventional_decimals=2, name="Panamanian balboa", symbol="B/."),
|
|
180
|
+
Currency(code="PEN", num=604, conventional_decimals=2, name="Peruvian sol", symbol="S/"),
|
|
181
|
+
Currency(
|
|
182
|
+
code="PGK", num=598, conventional_decimals=2, name="Papua New Guinean kina", symbol="K"
|
|
183
|
+
),
|
|
184
|
+
Currency(code="PHP", num=608, conventional_decimals=2, name="Philippine peso", symbol="\u20b1"),
|
|
185
|
+
Currency(code="PKR", num=586, conventional_decimals=2, name="Pakistani rupee", symbol="Pre"),
|
|
186
|
+
Currency(code="PLN", num=985, conventional_decimals=2, name="Polish złoty", symbol="z\u0142"),
|
|
187
|
+
Currency(
|
|
188
|
+
code="PYG", num=600, conventional_decimals=0, name="Paraguayan guaraní", symbol="\u20b2"
|
|
189
|
+
),
|
|
190
|
+
Currency(code="QAR", num=634, conventional_decimals=2, name="Qatari riyal", symbol="QR"),
|
|
191
|
+
Currency(code="RON", num=946, conventional_decimals=2, name="Romanian leu", symbol=None),
|
|
192
|
+
Currency(code="RSD", num=941, conventional_decimals=2, name="Serbian dinar", symbol="DIN"),
|
|
193
|
+
Currency(code="RUB", num=643, conventional_decimals=2, name="Russian ruble", symbol="\u20bd"),
|
|
194
|
+
Currency(code="RWF", num=646, conventional_decimals=0, name="Rwandan franc", symbol="FRw"),
|
|
195
|
+
Currency(code="SAR", num=682, conventional_decimals=2, name="Saudi riyal", symbol="\u20c2"),
|
|
196
|
+
Currency(
|
|
197
|
+
code="SBD", num=90, conventional_decimals=2, name="Solomon Islands dollar", symbol="SI$"
|
|
198
|
+
),
|
|
199
|
+
Currency(code="SCR", num=690, conventional_decimals=2, name="Seychelles rupee", symbol="Sre"),
|
|
200
|
+
Currency(code="SDG", num=938, conventional_decimals=2, name="Sudanese pound", symbol="LS"),
|
|
201
|
+
Currency(code="SEK", num=752, conventional_decimals=2, name="Swedish krona", symbol="kr"),
|
|
202
|
+
Currency(code="SGD", num=702, conventional_decimals=2, name="Singapore dollar", symbol="S$"),
|
|
203
|
+
Currency(
|
|
204
|
+
code="SHP", num=654, conventional_decimals=2, name="Saint Helena pound", symbol="\u00a3"
|
|
205
|
+
),
|
|
206
|
+
Currency(
|
|
207
|
+
code="SLE", num=925, conventional_decimals=2, name="Sierra Leonean leone", symbol="Le"
|
|
208
|
+
),
|
|
209
|
+
Currency(
|
|
210
|
+
code="SOS", num=706, conventional_decimals=2, name="Somalian shilling", symbol="Sh.So."
|
|
211
|
+
),
|
|
212
|
+
Currency(code="SRD", num=968, conventional_decimals=2, name="Surinamese dollar", symbol=None),
|
|
213
|
+
Currency(
|
|
214
|
+
code="SSP", num=728, conventional_decimals=2, name="South Sudanese pound", symbol="SSP"
|
|
215
|
+
),
|
|
216
|
+
Currency(
|
|
217
|
+
code="STN",
|
|
218
|
+
num=930,
|
|
219
|
+
conventional_decimals=2,
|
|
220
|
+
name="São Tomé and Príncipe dobra",
|
|
221
|
+
symbol="Db",
|
|
222
|
+
),
|
|
223
|
+
Currency(
|
|
224
|
+
code="SVC", num=222, conventional_decimals=2, name="Salvadoran colón", symbol="\u20a1"
|
|
225
|
+
),
|
|
226
|
+
Currency(code="SYP", num=760, conventional_decimals=2, name="Syrian pound", symbol="LS"),
|
|
227
|
+
Currency(code="SZL", num=748, conventional_decimals=2, name="Swazi lilangeni", symbol="E"),
|
|
228
|
+
Currency(code="THB", num=764, conventional_decimals=2, name="Thai baht", symbol="\u0e3f"),
|
|
229
|
+
Currency(code="TJS", num=972, conventional_decimals=2, name="Tajikistani somoni", symbol="SM"),
|
|
230
|
+
Currency(
|
|
231
|
+
code="TMT", num=934, conventional_decimals=2, name="Turkmenistan manat", symbol="\u20bc"
|
|
232
|
+
),
|
|
233
|
+
Currency(code="TND", num=788, conventional_decimals=3, name="Tunisian dinar", symbol="DT"),
|
|
234
|
+
Currency(code="TOP", num=776, conventional_decimals=2, name="Tongan paʻanga", symbol="T$"),
|
|
235
|
+
Currency(code="TRY", num=949, conventional_decimals=2, name="Turkish lira", symbol="\u20ba"),
|
|
236
|
+
Currency(
|
|
237
|
+
code="TTD",
|
|
238
|
+
num=780,
|
|
239
|
+
conventional_decimals=2,
|
|
240
|
+
name="Trinidad and Tobago dollar",
|
|
241
|
+
symbol="TT$",
|
|
242
|
+
),
|
|
243
|
+
Currency(code="TWD", num=901, conventional_decimals=2, name="New Taiwan dollar", symbol="NT$"),
|
|
244
|
+
Currency(code="TZS", num=834, conventional_decimals=2, name="Tanzanian shilling", symbol="TSh"),
|
|
245
|
+
Currency(
|
|
246
|
+
code="UAH", num=980, conventional_decimals=2, name="Ukrainian hryvnia", symbol="\u20b4"
|
|
247
|
+
),
|
|
248
|
+
Currency(code="UGX", num=800, conventional_decimals=0, name="Ugandan shilling", symbol="Ush"),
|
|
249
|
+
Currency(code="USD", num=840, conventional_decimals=2, name="United States dollar", symbol="$"),
|
|
250
|
+
Currency(
|
|
251
|
+
code="USN",
|
|
252
|
+
num=997,
|
|
253
|
+
conventional_decimals=2,
|
|
254
|
+
name="United States dollar (next day),",
|
|
255
|
+
symbol="$",
|
|
256
|
+
),
|
|
257
|
+
Currency(
|
|
258
|
+
code="UYI",
|
|
259
|
+
num=940,
|
|
260
|
+
conventional_decimals=0,
|
|
261
|
+
name="Uruguay Peso en Unidades Indexadas (URUIURUI), (funds code),",
|
|
262
|
+
symbol=None,
|
|
263
|
+
),
|
|
264
|
+
Currency(code="UYU", num=858, conventional_decimals=2, name="Uruguayan peso", symbol="$U"),
|
|
265
|
+
Currency(code="UYW", num=927, conventional_decimals=4, name="Unidad previsional", symbol=None),
|
|
266
|
+
Currency(code="UZS", num=860, conventional_decimals=2, name="Uzbekistani sum", symbol="sum"),
|
|
267
|
+
Currency(
|
|
268
|
+
code="VED", num=926, conventional_decimals=2, name="Venezuelan digital bolívar", symbol="Bs"
|
|
269
|
+
),
|
|
270
|
+
Currency(
|
|
271
|
+
code="VES",
|
|
272
|
+
num=928,
|
|
273
|
+
conventional_decimals=2,
|
|
274
|
+
name="Venezuelan sovereign bolívar",
|
|
275
|
+
symbol="Bs",
|
|
276
|
+
),
|
|
277
|
+
Currency(code="VND", num=704, conventional_decimals=0, name="Vietnamese đồng", symbol="\u20ab"),
|
|
278
|
+
Currency(code="VUV", num=548, conventional_decimals=0, name="Vanuatu vatu", symbol="VT"),
|
|
279
|
+
Currency(code="WST", num=882, conventional_decimals=2, name="Samoan tala", symbol="WS$"),
|
|
280
|
+
Currency(code="XAF", num=950, conventional_decimals=0, name="CFA franc BEAC", symbol=None),
|
|
281
|
+
Currency(code="XAG", num=961, conventional_decimals=3, name="Silver", symbol=None),
|
|
282
|
+
Currency(code="XAU", num=959, conventional_decimals=3, name="Gold", symbol=None),
|
|
283
|
+
Currency(
|
|
284
|
+
code="XBA",
|
|
285
|
+
num=955,
|
|
286
|
+
conventional_decimals=3,
|
|
287
|
+
name="European Composite Unit (EURCO), (bond market unit),",
|
|
288
|
+
symbol=None,
|
|
289
|
+
),
|
|
290
|
+
Currency(
|
|
291
|
+
code="XBB",
|
|
292
|
+
num=956,
|
|
293
|
+
conventional_decimals=3,
|
|
294
|
+
name="European Monetary Unit (E.M.U.-6), (bond market unit),",
|
|
295
|
+
symbol=None,
|
|
296
|
+
),
|
|
297
|
+
Currency(
|
|
298
|
+
code="XBC",
|
|
299
|
+
num=957,
|
|
300
|
+
conventional_decimals=3,
|
|
301
|
+
name="European Unit of Account 9 (E.U.A.-9), (bond market unit),",
|
|
302
|
+
symbol=None,
|
|
303
|
+
),
|
|
304
|
+
Currency(
|
|
305
|
+
code="XBD",
|
|
306
|
+
num=958,
|
|
307
|
+
conventional_decimals=3,
|
|
308
|
+
name="European Unit of Account 17 (E.U.A.-17), (bond market unit),",
|
|
309
|
+
symbol=None,
|
|
310
|
+
),
|
|
311
|
+
Currency(
|
|
312
|
+
code="XCD", num=951, conventional_decimals=2, name="East Caribbean dollar", symbol="EC$"
|
|
313
|
+
),
|
|
314
|
+
Currency(
|
|
315
|
+
code="XCG",
|
|
316
|
+
num=532,
|
|
317
|
+
conventional_decimals=2,
|
|
318
|
+
name="Netherlands Antillean guilder",
|
|
319
|
+
symbol="\u0192",
|
|
320
|
+
),
|
|
321
|
+
Currency(
|
|
322
|
+
code="XDR", num=960, conventional_decimals=3, name="Special drawing rights", symbol=None
|
|
323
|
+
),
|
|
324
|
+
Currency(code="XOF", num=952, conventional_decimals=0, name="CFA franc BCEAO", symbol=None),
|
|
325
|
+
Currency(code="XPD", num=964, conventional_decimals=3, name="Palladium", symbol=None),
|
|
326
|
+
Currency(
|
|
327
|
+
code="XPF",
|
|
328
|
+
num=953,
|
|
329
|
+
conventional_decimals=0,
|
|
330
|
+
name="CFP franc (franc Pacifique),",
|
|
331
|
+
symbol="F",
|
|
332
|
+
),
|
|
333
|
+
Currency(code="XPT", num=962, conventional_decimals=3, name="Platinum", symbol=None),
|
|
334
|
+
Currency(code="XSU", num=994, conventional_decimals=3, name="SUCRE", symbol=None),
|
|
335
|
+
Currency(
|
|
336
|
+
code="XTS", num=963, conventional_decimals=3, name="Code reserved for testing", symbol=None
|
|
337
|
+
),
|
|
338
|
+
Currency(code="XUA", num=965, conventional_decimals=3, name="ADB Unit of Account", symbol=None),
|
|
339
|
+
Currency(code="XXX", num=999, conventional_decimals=3, name="No currency", symbol=None),
|
|
340
|
+
Currency(code="YER", num=886, conventional_decimals=2, name="Yemeni rial", symbol="Yrl"),
|
|
341
|
+
Currency(code="ZAR", num=710, conventional_decimals=2, name="South African rand", symbol="R"),
|
|
342
|
+
Currency(code="ZMW", num=967, conventional_decimals=2, name="Zambian kwacha", symbol="K"),
|
|
343
|
+
Currency(code="ZWG", num=924, conventional_decimals=2, name="Zimbabwe Gold", symbol="ZiG"),
|
|
344
|
+
]
|
|
345
|
+
ISO_CODE_TO_CURRENCY = {c.code: c for c in CURRENCIES}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
from typing import TypedDict
|
|
2
|
+
|
|
3
|
+
from strenum import StrEnum
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
class PeriodType(StrEnum):
|
|
7
|
+
"""The period type"""
|
|
8
|
+
|
|
9
|
+
annual = "annual"
|
|
10
|
+
quarterly = "quarterly"
|
|
11
|
+
ltm = "ltm"
|
|
12
|
+
ytd = "ytd"
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
class Periodicity(StrEnum):
|
|
16
|
+
"""The frequency or interval at which the historical data points are sampled or aggregated. Periodicity is not the same as the date range. The date range specifies the time span over which the data is retrieved, while periodicity determines how the data within that date range is aggregated."""
|
|
17
|
+
|
|
18
|
+
day = "day"
|
|
19
|
+
week = "week"
|
|
20
|
+
month = "month"
|
|
21
|
+
year = "year"
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
class YearAndQuarter(TypedDict):
|
|
25
|
+
year: int
|
|
26
|
+
quarter: int
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
class LatestAnnualPeriod(TypedDict):
|
|
30
|
+
latest_year: int
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
class LatestQuarterlyPeriod(TypedDict):
|
|
34
|
+
latest_quarter: int
|
|
35
|
+
latest_year: int
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
class CurrentPeriod(TypedDict):
|
|
39
|
+
current_year: int
|
|
40
|
+
current_quarter: int
|
|
41
|
+
current_month: int
|
|
42
|
+
current_date: str
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
class LatestPeriods(TypedDict):
|
|
46
|
+
annual: LatestAnnualPeriod
|
|
47
|
+
quarterly: LatestQuarterlyPeriod
|
|
48
|
+
now: CurrentPeriod
|