EDINET API client & XBRL parser for Japanese financial disclosures
Project description
edinet — EDINET XBRL 財務データ Python ライブラリ
edinet は、EDINET(金融庁 電子開示システム)の開示データを Python から扱うためのライブラリです。書類一覧の取得から XBRL パース、財務三表(PL/BS/CF)の組み立て、会計基準の自動判別、23 業種対応、タクソノミラベル解決、DataFrame 変換までをワンストップで提供します。全 42 書類タイプに対応し、J-GAAP / IFRS / US-GAAP の 3 会計基準を統一的に扱えます。内部の HTTP 通信には httpx を使用しています。
インストール
pip install edinet
オプション依存:
# pandas + Parquet 連携
pip install 'edinet[analysis]'
# Rich ターミナル表示
pip install 'edinet[display]'
# 全部入り
pip install 'edinet[analysis,display]'
設定
必要なもの
| 項目 | 用途 | 必須? |
|---|---|---|
| EDINET API キー | 書類一覧・ZIP ダウンロード | 必須 |
| EDINET タクソノミ | XBRL 解析(三表・ラベル・CK 抽出すべて) | XBRL 解析に必須 |
| キャッシュディレクトリ | ZIP の再ダウンロード防止 | 任意(推奨) |
注意: タクソノミなしでも企業検索(
Company.search)、書類一覧(documents())、PDF 取得(fetch_pdf())は動作しますが、filing.xbrl()以降の全機能(三表取得・ラベルアクセス・DataFrame 変換・extract_values 等)にはタクソノミが必要です。
タクソノミのセットアップ
- 金融庁の EDINET タクソノミページから「EDINET タクソノミ」の ZIP をダウンロード(年度により URL が変わります)
- ZIP を展開すると、中に
taxonomy/とsamples/を子に持つフォルダがあります:(ZIP を展開) └── ○○○/ ← フォルダ名は年度により異なる ├── taxonomy/ ← タクソノミ本体 └── samples/ ← サンプルインスタンス taxonomy/とsamples/の親フォルダのパスを指定:
import edinet
edinet.configure(
api_key="YOUR_API_KEY",
taxonomy_path="/path/to/○○○", # ← taxonomy/ の親
cache_dir="./cache", # 任意(推奨)
)
API キーの取得
EDINET にアカウント登録し、API キーを取得してください。
クイックスタート
import edinet
edinet.configure(
api_key="YOUR_API_KEY",
taxonomy_path="/path/to/○○○"
)
# 有価証券報告書の一覧を取得
filings = edinet.documents("2025-06-26", doc_type=edinet.DocType.ANNUAL_SECURITIES_REPORT)
# 最初の XBRL 付き Filing から財務諸表を取得
for filing in filings:
if filing.has_xbrl:
stmts = filing.xbrl()
pl = stmts.income_statement()
bs = stmts.balance_sheet()
cf = stmts.cash_flow_statement()
print(f"{filing.filer_name}({filing.ticker})")
print(f" 売上高: {pl['売上高'].value:,}")
# extract_values を使えば会計基準・ラベル表記を問わず取得可能
from edinet import extract_values, CK
result = extract_values(stmts, [CK.OPERATING_INCOME, CK.TOTAL_ASSETS])
print(f" 営業利益: {result[CK.OPERATING_INCOME].value:,}")
print(f" 総資産: {result[CK.TOTAL_ASSETS].value:,}")
break
企業検索
11,000 社超の EDINET コードマスタを内蔵しています。企業名・銘柄コード・EDINET コードから検索できます。
from edinet import Company
# 企業名で検索(部分一致、複数ヒット)
results = Company.search("トヨタ自動車")
toyota = results[0]
print(toyota.name_ja) # "トヨタ自動車株式会社"
print(toyota.ticker) # "7203"
# 銘柄コードから
sony = Company.from_sec_code("6758")
# EDINET コードから
company = Company.from_edinet_code("E02144")
# 最新の有報を取得(デフォルト: 過去90日間を検索)
filing = toyota.latest(doc_type=edinet.DocType.ANNUAL_SECURITIES_REPORT)
if filing is not None:
stmts = filing.xbrl()
書類タイプ
全 42 書類タイプを DocType enum で定義しています。日本語名や訂正関係もプロパティで取得できます。
from edinet import DocType
dt = DocType.ANNUAL_SECURITIES_REPORT
print(dt.name_ja) # "有価証券報告書"
print(dt.is_correction) # False
# 訂正報告書から元の書類を辿る
corrected = DocType.AMENDED_ANNUAL_SECURITIES_REPORT
print(corrected.original) # DocType.ANNUAL_SECURITIES_REPORT
# 書類タイプでフィルタして取得
filings = edinet.documents("2025-06-26", doc_type=DocType.ANNUAL_SECURITIES_REPORT)
書類タイプ別のアクセス方法
書類タイプに応じて 3 つのアクセス層を使い分けます。
| 書類 | 例 | アクセス方法 |
|---|---|---|
| 有報系(7 タイプ) | 有報、四半期報告書、半期報告書 | stmts.income_statement() 等で三表取得 |
| その他 XBRL 書類(27 タイプ) | 大量保有報告書、公開買付届出書、臨時報告書 | stmts["ラベル名"] で全 Fact にアクセス |
| PDF のみ(8 タイプ) | 有価証券通知書、届出の取下げ | filing.fetch_pdf() でバイナリ取得 |
# 有報系: 三表 + ラベルアクセス
stmts = filing.xbrl()
pl = stmts.income_statement()
pl["売上高"].value
# 大量保有報告書など: ラベルで直接アクセス(三表なし)
stmts = filing.xbrl()
ratio = stmts.get("保有割合の合計")
stmts.search("保有") # キーワードで部分一致検索
# PDF のみの書類
pdf_bytes = filing.fetch_pdf()
with open("report.pdf", "wb") as f:
f.write(pdf_bytes)
財務諸表
三表の取得
stmts = filing.xbrl()
# 連結・当期(デフォルト)
pl = stmts.income_statement()
bs = stmts.balance_sheet()
cf = stmts.cash_flow_statement()
# 前期
pl_prior = stmts.income_statement(period="prior")
# 個別
pl_solo = stmts.income_statement(consolidated=False)
科目アクセス
日本語ラベル・英語ラベル・concept 名のいずれでも完全一致でアクセスできます。
# 日本語ラベルで取得(完全一致)
item = pl["売上高"]
print(item.value) # Decimal('1234567000000')
print(item.unit_ref) # "JPY"
# 英語ラベル / concept 名でも OK
item = pl["Net sales"]
item = pl["NetSales"]
# 安全なアクセス(KeyError を避ける)
item = pl.get("売上高") # LineItem | None
注意:
get()/__getitem__はタクソノミの正式ラベルとの完全一致です。 例えばpl.get("営業利益")はNoneを返します(正式ラベルは"営業利益又は営業損失(△)")。 正式ラベルが分からない場合はsearch()で部分一致検索するか、extract_values()で canonical key を指定してください。
# 部分一致検索: ラベルにキーワードを含む全科目を返す
hits = stmts.search("営業利益")
print(hits[0].label_ja.text) # "営業利益又は営業損失(△)"
# canonical key: 会計基準・ラベル表記に依存しない安定的な取得方法
from edinet import extract_values, CK
result = extract_values(stmts, [CK.OPERATING_INCOME])
print(result[CK.OPERATING_INCOME].value) # 確実に取得
会計基準の自動判別
会計基準は DEI から自動判別されます。J-GAAP・IFRS・US-GAAP のいずれでも同じ API で操作できます。
print(stmts.detected_standard) # "J-GAAP"
print(repr(stmts.detected_standard)) # DetectedStandard(standard=<...>, method=<DEI>, ...)
# IFRS 企業でも同じコードで動く
sony_stmts = sony_filing.xbrl()
sony_pl = sony_stmts.income_statement()
sony_pl["売上収益"].value # IFRS の Revenue
2つのデータ取得方式
財務データの取得には 2 つの方式があります。用途に応じて使い分けてください。
income_statement() 等 |
extract_values() |
|
|---|---|---|
| データソース | Presentation Linkbase(タクソノミ定義) | 3 層信頼度モデル(Summary → 辞書 → 正規化) |
| 取得範囲 | PL/BS/CF の全詳細科目(数十行) | 主要指標(売上高・営業利益・のれん・有利子負債等) |
| 表示順 | タクソノミの表示順序付き | なし(辞書) |
| 基準横断 | 基準ごとに科目名が異なる | 基準を問わず同じキーで取得 |
| 用途 | 財務諸表の表示・分析 | スクリーナー・DB 永続化・複数企業の横並び比較 |
# 方式1: 財務諸表として取得(全科目・表示順付き)
pl = stmts.income_statement()
for item in pl:
print(f"{item.label_ja.text}: {item.value}")
# 方式2: 正規化キーで横断取得(主要指標・基準不問)
result = extract_values(stmts, [CK.REVENUE, CK.TOTAL_ASSETS])
正規化キーによる基準横断アクセス
canonical key (CK) を使うと、会計基準を意識せずに値を取得できます。スクリーナーや DB 永続化に最適です。
from edinet import extract_values, extracted_to_dict, CK
stmts = filing.xbrl()
# 当期・連結(デフォルト: period=None, consolidated=None で全期間・全区分から先頭マッチ)
result = extract_values(stmts, [CK.REVENUE, CK.OPERATING_INCOME, CK.GOODWILL])
# 当期・連結を明示指定
result = extract_values(stmts, [CK.REVENUE], period="current", consolidated=True)
# 前期
result = extract_values(stmts, [CK.REVENUE], period="prior")
# 個別(非連結)
result = extract_values(stmts, [CK.REVENUE], consolidated=False)
rev = result[CK.REVENUE]
print(rev.value) # Decimal('1234567000000')
print(rev.source) # "summary" / "exact" / "normalized"
print(rev.item.label_ja.text) # "売上高"(J-GAAP)or "売上収益"(IFRS)
print(rev.item.local_name) # マッチした concept 名
# 信頼度でフィルタ(normalized を除外)
safe = {k: v for k, v in result.items() if v and v.source != "normalized"}
# Summary のみ(PL/BS/CF 本体からの補完を無効化)
result = extract_values(stmts, [CK.REVENUE], include_statements=False)
# pandas で複数企業を横並び
import pandas as pd
keys = [CK.REVENUE, CK.OPERATING_INCOME, CK.NET_INCOME, CK.TOTAL_ASSETS]
df = pd.DataFrame([
{
"ticker": f.ticker,
"filer": f.filer_name,
**extracted_to_dict(extract_values(f.xbrl(), keys, period="current", consolidated=True)),
}
for f in filings if f.has_xbrl
])
パラメータ
| パラメータ | デフォルト | 説明 |
|---|---|---|
keys |
None |
抽出するキー。None で全マッピング可能科目 |
period |
None |
"current" / "prior" / None(全期間から先頭マッチ) |
consolidated |
None |
True(連結)/ False(個別)/ None(全区分) |
include_statements |
True |
False で層 2・3 を無効化(Summary のみ) |
3 層信頼度モデル
extract_values() は 3 層で値を探索し、source フィールドで出所を明示します。
| 層 | source |
データソース | 信頼度 |
|---|---|---|---|
| 1 | "summary" |
SummaryOfBusinessResults(完全一致) | 最高 |
| 2 | "exact" |
PL/BS/CF 本体 + 注記の辞書完全一致 | 高 |
| 3 | "normalized" |
EDINET サフィックス剥離後に辞書引き | 低 |
上位層の結果は下位層で上書きされません。
DataFrame 変換・エクスポート
# FinancialStatement → DataFrame
df = pl.to_dataframe()
# → columns: label_ja, label_en, value, unit, concept
# 全カラム表示(トレーサビリティ情報込み)
df = pl.to_dataframe(full=True)
# → 18 columns: concept, namespace_uri, source_line, period_start, ...
# エクスポート
pl.to_csv("pl.csv")
pl.to_parquet("pl.parquet")
pl.to_excel("pl.xlsx")
# Statements 全体を DataFrame 化
df_all = stmts.to_dataframe()
Rich ターミナル表示
from rich.console import Console
# 財務諸表を階層表示
Console().print(pl)
Jupyter 表示
# セルに pl を置くだけで HTML テーブルが表示される
pl # _repr_html_ 対応
テキストブロック(LLM 連携)
有報のテキストセクション(事業等のリスク、MD&A 等)を構造的に抽出し、LLM に渡せます。
from edinet.xbrl.text import extract_text_blocks, build_section_map, clean_html
blocks = extract_text_blocks(parsed.facts, context_map)
sections = build_section_map(blocks, resolver)
# セクション名でアクセス(tuple[TextBlock, ...] が返る)
risk_blocks = sections["事業等のリスク"]
clean_text = clean_html(risk_blocks[0].html) # HTML → プレーンテキスト
タクソノミ・リンクベース
ラベル解決
from edinet.xbrl.taxonomy import TaxonomyResolver
resolver = TaxonomyResolver(taxonomy_path)
label = resolver.resolve("jppfs_cor", "NetSales", lang="ja")
print(label.text) # "売上高"
print(label.source) # LabelSource.STANDARD
Linkbase 解析
from edinet.xbrl.linkbase import (
parse_presentation_linkbase,
parse_calculation_linkbase,
parse_definition_linkbase,
parse_footnote_links,
)
# Presentation: 表示順序の木構造
pres_trees = parse_presentation_linkbase(pres_xml_bytes)
# Calculation: 計算関係(親子の加減算)
calc_lb = parse_calculation_linkbase(calc_xml_bytes)
# Definition: Dimension 定義(軸・ドメイン・メンバー)
def_trees = parse_definition_linkbase(def_xml_bytes)
# Footnotes: 脚注リンク
footnote_map = parse_footnote_links(parsed.footnote_links)
ConceptSet 自動導出
Presentation Linkbase をスキャンして 23 業種 × PL/BS/CF/SS/CI の科目セットを自動導出します。
from edinet.xbrl.taxonomy.concept_sets import derive_concept_sets, StatementType
registry = derive_concept_sets(taxonomy_path)
cs = registry.get(StatementType.INCOME_STATEMENT, consolidated=True, industry_code="cai")
for entry in cs.concepts[:5]:
print(entry.concept, entry.depth, entry.is_total)
計算検証
Calculation Linkbase に基づき、親科目 = Σ(子科目 × weight) の整合性を検証します。
from edinet import validate_calculations
result = validate_calculations(pl, calc_linkbase)
print(result.is_valid) # True / False
print(result.checked_count) # 検証した計算関係の数
for issue in result.issues:
print(f"{issue.parent_concept}: 差額 {issue.difference}")
訂正チェーン
訂正報告書の連鎖を自動的に辿り、最新版や任意時点のスナップショットを取得できます。
from edinet import build_revision_chain
chain = build_revision_chain(filing)
print(chain.is_corrected) # True(訂正あり)
print(chain.count) # チェーンの長さ
original = chain.original # 原本
latest = chain.latest # 最新(訂正済み)
# バックテスト用: 特定日時点のスナップショット
snapshot = chain.at_time(datetime(2025, 9, 1))
訂正差分・期間差分
from edinet import diff_revisions, diff_periods
# 訂正前 vs 訂正後の Fact レベル差分
result = diff_revisions(original_stmts, corrected_stmts)
for item in result.modified:
print(f"{item.label_ja.text}: {item.old_value} → {item.new_value}")
# 前期 vs 当期の科目増減
pl_prior = stmts.income_statement(period="prior")
pl_current = stmts.income_statement(period="current")
period_diff = diff_periods(pl_prior, pl_current)
print(period_diff.summary()) # "追加: 2, 削除: 1, 変更: 3, 変更なし: 50"
セグメント分析
事業セグメント・地域セグメント等の多次元データを構造的に取得できます。
from edinet import list_dimension_axes, extract_segments
# 利用可能な Dimension 軸を確認
axes = list_dimension_axes(stmts)
for axis in axes:
print(f"{axis.label_ja}: {axis.member_count} メンバー")
# 事業セグメントのデータを抽出
segments = extract_segments(stmts, axis_local_name="OperatingSegmentsAxis")
for seg in segments:
print(f"{seg.name}: {len(seg.items)} 科目")
非標準科目の判定
提出者が独自に追加した科目を識別し、標準タクソノミの祖先概念を推定します。
from edinet import detect_custom_items
result = detect_custom_items(stmts)
print(f"標準科目: {len(result.standard_items)}")
print(f"独自科目: {len(result.custom_items)} ({result.custom_ratio:.1%})")
for ci in result.custom_items:
print(f" {ci.item.label_ja.text} → 標準祖先: {ci.parent_standard_concept}")
Calculation Linkbase から提出者拡張科目のみを抽出することもできます。
from edinet import find_custom_concepts
custom_concepts = find_custom_concepts(calc_linkbase)
print(f"拡張科目数: {len(custom_concepts)}")
変則決算の判定
6ヶ月決算・15ヶ月決算等の変則決算を検出します。スクリーニング時の期間比較に必要です。
from edinet import detect_fiscal_year
info = detect_fiscal_year(dei)
print(info.period_months) # 12(通常)/ 6, 15 等(変則)
print(info.is_irregular) # True なら変則決算
print(info.is_full_year) # True なら通年
print(info.start_date) # 会計期間の開始日
print(info.end_date) # 会計期間の終了日
従業員情報
「従業員の状況」から人数・平均年齢・平均勤続年数・平均年間給与を抽出します。
from edinet.financial.notes.employees import extract_employee_info
info = extract_employee_info(stmts)
if info is not None:
print(info.count) # 従業員数
print(info.average_age) # 平均年齢
print(info.average_service_years) # 平均勤続年数
print(info.average_annual_salary) # 平均年間給与(円)
Filing サマリー
from edinet import build_summary
summary = build_summary(stmts)
print(summary.accounting_standard) # "Japan GAAP"
print(summary.total_items) # 3247
print(summary.standard_item_ratio) # 0.89
print(summary.segment_count) # 4
非同期クライアント
全 I/O 操作に async 版を提供しています。a プレフィクスを付けるだけです。
import asyncio
import edinet
async def main():
edinet.configure(api_key="YOUR_API_KEY")
filings = await edinet.adocuments("2025-06-26")
for filing in filings:
if filing.has_xbrl:
stmts = await filing.axbrl()
pl = stmts.income_statement()
print(pl["売上高"].value)
break
asyncio.run(main())
複数企業の並列取得
asyncio.gather を使うと、複数企業の XBRL を並列ダウンロードして大幅に高速化できます。
import asyncio
import edinet
from edinet import extract_values, extracted_to_dict, CK
async def screener():
edinet.configure(api_key="YOUR_API_KEY", taxonomy_path="...")
filings = await edinet.adocuments("2025-06-26", doc_type="120")
targets = [f for f in filings if f.has_xbrl][:20]
# 20社を並列ダウンロード+パース(直列60s → 並列5-10s)
stmts_list = await asyncio.gather(*[f.axbrl() for f in targets])
keys = [CK.REVENUE, CK.OPERATING_INCOME, CK.NET_INCOME, CK.TOTAL_ASSETS]
rows = []
for f, stmts in zip(targets, stmts_list):
rows.append({
"ticker": f.ticker,
"filer": f.filer_name,
**extracted_to_dict(extract_values(stmts, keys)),
})
import pandas as pd
df = pd.DataFrame(rows)
print(df)
await edinet.aclose()
asyncio.run(screener())
期間分類
DEI から当期/前期の期間を自動分類します。income_statement(period="prior") の内部で使用されていますが、直接アクセスも可能です。
from edinet.financial import classify_periods
pc = classify_periods(dei)
print(pc.current_duration) # DurationPeriod(2024-04-01, 2025-03-31)
print(pc.prior_duration) # DurationPeriod(2023-04-01, 2024-03-31)
print(pc.current_instant) # InstantPeriod(2025-03-31)
キャッシュ
ダウンロード済み ZIP のローカルキャッシュ。同一ドキュメントの再取得を防ぎます。
import edinet
# キャッシュを有効化(ディレクトリ指定)
edinet.configure(api_key="...", cache_dir="./cache")
# キャッシュ情報
info = edinet.cache_info()
print(info.entry_count, info.total_bytes)
# キャッシュクリア
edinet.clear_cache()
レートリミット
デフォルトではレートリミットは無効(rate_limit=0)です。EDINET API は指数バックオフ付きリトライを内蔵しているため、通常はレートリミット不要です。大量リクエスト時に接続遮断が心配な場合は手動で設定してください。
edinet.configure(rate_limit=1.0) # 1秒に1リクエスト
edinet.configure(rate_limit=0.5) # 500msに1リクエスト
edinet.configure(rate_limit=0) # 制限なし(デフォルト)
エラーハンドリング
すべての例外は edinet.EdinetError を継承しています。
import edinet
try:
filings = edinet.documents("2025-06-26")
except edinet.EdinetConfigError:
print("API キーが未設定")
except edinet.EdinetAPIError as e:
print(f"API エラー: {e.status_code}")
except edinet.EdinetParseError:
print("XBRL の解析に失敗")
| 例外クラス | 説明 |
|---|---|
EdinetError |
基底例外 |
EdinetConfigError |
設定エラー(API キー未設定等) |
EdinetAPIError |
API レスポンスエラー(HTTP ステータス付き) |
EdinetParseError |
JSON / ZIP / XBRL の解析失敗 |
EdinetWarning |
非致命的な警告(warnings モジュール経由) |
低レベル API
高レベル API の裏側にある XBRL パーサーを直接使うこともできます。
from edinet.xbrl import parse_xbrl_facts, extract_dei
from edinet.xbrl.contexts import ContextCollection, structure_contexts
from edinet.xbrl.units import structure_units
# XBRL インスタンスのパース
xbrl_path, xbrl_bytes = filing.fetch()
parsed = parse_xbrl_facts(xbrl_bytes, source_path=xbrl_path)
# DEI(企業属性)の抽出
dei = extract_dei(parsed.facts)
print(dei.filer_name_ja) # 企業名
print(dei.accounting_standards) # AccountingStandard.JAPAN_GAAP
print(dei.security_code) # 証券コード
# Context / Unit の構造化
contexts = ContextCollection(structure_contexts(parsed.contexts))
units = structure_units(parsed.units)
# フィルタチェーン
consolidated = contexts.filter_consolidated().filter_no_extra_dimensions()
latest = consolidated.latest_duration_contexts()
対応範囲
| 項目 | 対応状況 |
|---|---|
| 書類タイプ | 全 42 タイプ |
| 会計基準 | J-GAAP / IFRS / US-GAAP / JMIS |
| 業種 | 23 業種(ConceptSet 自動導出)+ 5 業種の専用科目マッピング |
| 財務諸表 | BS / PL / CF |
| Linkbase | Presentation / Calculation / Definition / Footnotes |
| エクスポート | DataFrame / CSV / Parquet / Excel |
| 表示 | Rich ターミナル / Jupyter HTML |
| I/O | sync / async 完全対応 |
| テスト | 1,398+ |
動作要件
- Python >= 3.12
- EDINET API キー(EDINET で取得)
ライセンス
AGPL v3 とは
GNU Affero General Public License v3 は、ソフトウェアの自由な利用・改変・再配布を保証するコピーレフトライセンスです。ネットワーク経由でサービスを提供する場合にもソースコード公開義務が発生する点が GPL v3 との主な違いです。
利用可否の早見表
| 利用形態 | 可否 | 説明 |
|---|---|---|
| 個人の学習・研究 | OK | 自由に利用可能 |
| 社内の財務分析・スクリーニング | OK | 社内利用はソースコード公開義務なし |
| クオンツ運用・自社トレーディング | OK | 社内利用に該当。成果物(投資判断)の公開義務なし |
| 学術研究・論文 | OK | 自由に利用可能 |
| このライブラリを組み込んだ REST API / SaaS の公開 | NG | AGPL v3 によりサーバーサイドでもソースコード公開義務が発生。商用ライセンスが必要 |
| このライブラリを改変して社外に配布 | 条件付き | AGPL v3 の条件に従いソースコードを公開する必要あり |
商用ライセンス
AGPL v3 の条件に該当する商用利用(REST API / SaaS 等)をご検討の場合は、商用ライセンスをご相談ください。
お問い合わせ: https://x.com/___uxoxu
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file edinet-0.2.0.tar.gz.
File metadata
- Download URL: edinet-0.2.0.tar.gz
- Upload date:
- Size: 1.4 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ebca69f30c2ad79d8786b9dac2a09fc02f2f2fdfb464c6084ebad54f0ef8c478
|
|
| MD5 |
58e5441a1b869059d154572ed39d6d81
|
|
| BLAKE2b-256 |
5fa18b1a6addb438ab2d4eb04bc6e86e7e354fc1f4525a3f409ab37088449113
|
File details
Details for the file edinet-0.2.0-py3-none-any.whl.
File metadata
- Download URL: edinet-0.2.0-py3-none-any.whl
- Upload date:
- Size: 1.4 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c3929c9edef1a270175e4d9ad7e174d7267fa8f217d270f982b67d962e4e8e79
|
|
| MD5 |
c360cfb317eadd5afb3dcbd31ee2a185
|
|
| BLAKE2b-256 |
8a1a11947f416ae75a9baac9b50aa46e829672076eacece0460ab6fbea97bfbf
|