Structured financial data from SEC EDGAR filings — 10-Q, 10-K, and 8-K
Project description
edgar-parser
Structured financial data from SEC EDGAR filings.
Give your Python application access to income statements, balance sheets, cash flows, and qualitative sections from 10-Q, 10-K, and 8-K filings — parsed directly from SEC EDGAR with no third-party data vendor required.
This isn't a raw EDGAR scraper. The library handles XBRL namespace resolution, fiscal period matching, current vs. prior period alignment, sign normalization, and fuzzy metric lookup — so you get clean, analysis-ready data.
What it does
Core Extraction (parse_filing)
- Parses iXBRL facts from 10-Q and 10-K filings on SEC EDGAR
- Resolves XBRL namespaces, units, scales, and dimensional qualifiers
- Enriches facts with presentation roles and negated-label sign flipping
Period Matching (match_filing)
- Aligns current and prior period values for each financial line item
- Handles quarterly, full-year, and 4Q (derived annual) modes
- Zip-matching with adaptive fallback to fuzzy matching for edge cases
8-K Earnings Extraction (earnings_8k) — optional, requires anthropic or openai
- Extracts financial data from 8-K earnings press releases using Claude (primary) with OpenAI GPT-4o fallback
- Automatic fallback when 10-Q/10-K is not yet available for a period
- Same output schema as core extraction for seamless integration
Filing Sections (section_parser)
- Parses qualitative sections from 10-K/10-Q filings (Risk Factors, MD&A, Business, etc.)
- 8-K earnings release parsing via
source="8k"— extracts narrative and tables from Item 2.02 exhibits - Summary and full-text modes with configurable word limits
High-Level Tools (tools)
get_financials(ticker, year, quarter)— all facts for a filing periodget_filings(ticker, year, quarter)— list available filings (10-Q, 10-K, 8-K)get_metric(ticker, year, quarter, metric_name)— single metric lookup with fuzzy matchingget_filing_sections(ticker, year, quarter, source="8k")— qualitative section text (10-K/10-Q default, or 8-K earnings release)
Install
pip install edgar-parser
For 8-K earnings extraction (uses Claude API with OpenAI fallback):
pip install "edgar-parser[llm]"
Quick start
from edgar_parser.tools import get_financials, get_metric
# Get all financial facts from Apple's Q1 2025 10-Q
result = get_financials("AAPL", 2025, 1)
for fact in result["facts"][:5]:
print(f"{fact['metric']}: {fact['current_value']}")
# Look up a single metric
revenue = get_metric("AAPL", 2025, 1, "Revenue")
print(f"Revenue: {revenue['value']} {revenue['unit']}")
Or use the lower-level API for more control:
from edgar_parser import parse_filing, match_filing
# Parse raw XBRL facts
parsed = parse_filing("AAPL", 2025, 1, full_year_mode=False)
# Match current vs. prior periods
matched = match_filing(parsed)
print(matched.head())
Key functions
| Function | Module | Description |
|---|---|---|
get_financials |
tools |
All facts for a ticker/period, with caching |
get_filings |
tools |
List SEC filings (10-Q, 10-K, 8-K) for a period |
get_metric |
tools |
Single metric lookup with fuzzy matching |
get_filing_sections |
tools |
Qualitative section text (10-K/10-Q or 8-K with source="8k") |
parse_filing |
pipeline |
Low-level XBRL fact extraction |
enrich_filing |
pipeline |
Fiscal period categorization and enrichment |
match_filing |
matching |
Current vs. prior period alignment |
find_8k_for_period |
earnings_8k |
Find 8-K earnings release for a fiscal period |
Requirements
- Python 3.10+
- No API key needed — data comes directly from SEC EDGAR (public)
- Optional:
ANTHROPIC_API_KEYenvironment variable for 8-K extraction - Optional:
OPENAI_API_KEYenvironment variable for 8-K fallback when Anthropic API is unavailable
See also
- edgar-mcp — MCP server that exposes EDGAR financial data as AI agent tools. If you're building with Claude Code or another MCP-compatible agent, use this instead.
Project details
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 edgar_parser-0.3.1.tar.gz.
File metadata
- Download URL: edgar_parser-0.3.1.tar.gz
- Upload date:
- Size: 71.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
522fad9ae5aa7f2a766c9806cdab409c599c3d1dd33edc8d4fa2a90926d1030c
|
|
| MD5 |
1a21453884065b6401cca6ff50f2697d
|
|
| BLAKE2b-256 |
cebd81669caf9a9665d5d9a6d9145ee420ac71eea49f77651181d71997937e57
|
File details
Details for the file edgar_parser-0.3.1-py3-none-any.whl.
File metadata
- Download URL: edgar_parser-0.3.1-py3-none-any.whl
- Upload date:
- Size: 76.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5bf63cf842c8331abd46777a8eb24d1f3e008ec000f37f47201592e9f35049b4
|
|
| MD5 |
d8fb961d9711d5195c65a7f3b1488ae7
|
|
| BLAKE2b-256 |
f29493f5b4a8c4ba7fb2ee672a6b074de664bb5c20e2242422f079149c8f29ae
|