Yahoo Finance Data
Access stock quotes, charts, and financial data via the Yahoo Finance library.
Installation
- Make sure Claude is on your device and in your terminal.
Skills load from
~/.claude/skills/when Claude Code starts up — so you need it on your machine first. If you don't have it yet, install it once with the command below, then runclaudein any terminal to verify.One-time setupnpm i -g @anthropic-ai/claude-codeAlready have it? Skip ahead.
- Paste into Claude Code or into your terminal.
This copies the whole skill folder into
~/.claude/skills/yahoo-finance2-gadicc/— the SKILL.md plus any scripts, reference docs, or templates the skill ships with. Safe default: works for every skill.Faster alternative (instruction-only skills)
Skips the clone and grabs only the SKILL.md file. Don't use this if the skill ships Python scripts, reference markdowns, or asset templates — they won't be downloaded and the skill will fail when it tries to load them.
Quick install (SKILL.md only)Sign up to copy - Restart Claude Code.
Quit and reopen Claude Code (or any other agent that loads from
~/.claude/skills/). New skills are picked up on startup. - Just ask Claude.
Skills auto-activate when your request matches the skill's description — no slash command needed. Trigger phrases live in the skill's own frontmatter; you can read them in the “What this skill does” section above.
Prefer to read the source first? Open on GitHub.
When Claude uses it
Use when building with the yahoo-finance2 TypeScript/Deno/npm library, using its Yahoo Finance data modules, CLI, or MCP server, or contributing to the yahoo-finance2 repository including modules, validation schemas, cached fixtures, and npm/JSR build output.
What this skill does
yahoo-finance2
What this skill is for
Use this skill when a task involves yahoo-finance2, including:
- Adding Yahoo Finance market data to a server-side JavaScript/TypeScript app.
- Choosing between
quote,chart,historical,quoteSummary,fundamentalsTimeSeries,screener,options, or other modules. - Using the package CLI or bundled MCP server.
- Modifying this repository's Deno source, tests, generated schemas, docs, or npm output build.
This is an unofficial Yahoo Finance client. Do not describe it as a supported Yahoo API, and do not assume Yahoo data availability, freshness, or shape is guaranteed.
Using the package
Prefer the v3 class API:
import YahooFinance from "yahoo-finance2";
const yahooFinance = new YahooFinance();
const quote = await yahooFinance.quote("AAPL");
console.log(quote?.regularMarketPrice, quote?.currency);
Do not use old v1/v2 singleton patterns such as
yahooFinance.setGlobalConfig(). In v3, instantiate with
new YahooFinance(options).
This package is for server-side runtimes. Do not put direct Yahoo Finance calls in browser/client bundles; Yahoo's CORS and cookie behavior require a server, serverless, edge, Deno, Bun, or Node context.
Module selection
- Use
search(query)first when a symbol is uncertain. - Use
quote(symbolOrSymbols)for current or near real-time quote fields. It accepts one symbol or an array. Usefieldsto limit payloads; for keyed access, request object or map returns. - Use
quoteCombine(symbol)when many independent code paths need quote data; it debounces many single-symbol calls into fewerquote()requests. - Use
chart(symbol, { period1, period2, interval })for chart-ready historical data with events such as dividends and splits.return: "array"is easier to iterate;return: "object"mirrors Yahoo's native shape. - Use
historical()for a simpler OHLCV history interface. - Use
quoteSummary(symbol, { modules })for profile, price, summary detail, filings, ownership, recommendations, and other quote-summary modules. Request only the modules needed. - Use
fundamentalsTimeSeries()for financial statements. Since late 2024, quote-summary financial-statement modules such asincomeStatementHistory,balanceSheetHistory, andcashflowStatementHistoryprovide little data. - Use
options(symbol)for options chains. - Use
screener()instead of removed/deprecated daily gainers or losers modules. Common predefined screeners includeday_gainers,day_losers, andmost_actives. - Use
trendingSymbols(region),recommendationsBySymbol(), andinsights()for their specialized Yahoo Finance endpoints.
Reliability, validation, and errors
Wrap module calls in try/catch. Network errors, Yahoo API errors, delisted
symbols, missing data, and validation failures are expected operating
conditions.
By default, returned data is validated and coerced so known dates become Date
objects and known result shapes are safe to consume. If validation fails, fixing
the typed interface and regenerated schema is usually better than turning
validation off.
Only use { validateResult: false } when the caller accepts unknown output
and performs its own checks. Use { validateOptions: false } only when
experimenting with Yahoo query parameters that the library does not yet model.
The default client queue limits concurrent Yahoo requests. Use constructor or
per-call queue options when you need stricter rate behavior:
const yahooFinance = new YahooFinance({
queue: { concurrency: 2, interval: 250 },
});
CLI and MCP
For quick shell use:
npx yahoo-finance2 search AMZN
npx yahoo-finance2 quote AAPL
npx yahoo-finance2 quoteSummary NVDA '{"modules":["assetProfile","secFilings"]}'
JSON-looking positional arguments are parsed as JSON. Successful piped output is JSON-safe.
For MCP clients, the package includes a read-only Yahoo Finance MCP server:
npx -y -p yahoo-finance2 yahoo-finance-mcp
See docs/mcp.md for stdio, HTTP, embedded handler, and client registration
details.
Contributing in this repository
Read AGENTS.md and CONTRIBUTING.md first. This repo is Deno-first
TypeScript; npm output is generated.
Edit source files under src/, not generated files under npm/, unless the
task explicitly asks for generated output. Preserve local .ts import
extensions.
Public module files usually follow this pattern:
- Typed query/result interfaces are the source of truth.
- Files with
@yf-schemaimport their generated.schema.json. - Module functions call
this._moduleExec()with query defaults, runtime params, optional transforms, result transforms, schema keys, and module options. - Overloads distinguish validated results from
{ validateResult: false }, which returnsunknown.
When changing an exported interface in a file marked @yf-schema, run:
deno task schema
If adding a module, wire it through src/modules/index.ts, deno.json exports,
docs/README links, README module lists when relevant, tests, and any CLI/MCP
exposure only when the module should be user-facing there.
Tests and fixtures
Run all tests with:
deno task test
Run focused tests with:
deno task test src/modules/quote.test.ts
Use deno task test:serial src/modules/quote.test.ts when debugging or limiting
live Yahoo request concurrency.
Tests that touch Yahoo HTTP responses should call setupCache() from
tests/common.ts. Prefer the existing pattern:
const YahooFinance = createTestYahooFinance({ modules: { quote } });
const yf = new YahooFinance();
describe("quote", () => {
setupCache();
it("passes validation", async (t, onFinish) => {
await yf.quote("AAPL", {}, {
devel: { id: "quote-AAPL", t, onFinish },
});
});
});
Use fixture ids that match the module and scenario. FETCH_DEVEL=nocache forces
live network calls. FETCH_DEVEL=recache refreshes cache files for failing
tests. Do not recache fixtures ending in .static.json or .fake.json; they
are intentionally stable or synthetic.
When fixing validation failures, inspect the validation error path and cached Yahoo response, update the TypeScript interface first, run schema generation, then run the focused test.
Build, lint, and release surface
Use these checks as appropriate:
deno fmt
deno lint
deno task test
deno task build:npm
scripts/build_npm.ts controls the generated npm package metadata, binaries,
dependencies, copied files, and package keywords. Keep npm-package changes there
unless explicitly regenerating npm/.
Commit messages should use Conventional Commits with a scope, such as
fix(quote): handle missing extended market fields.
Agent skill installation
The canonical skill lives at skills/yahoo-finance2/SKILL.md. To install it
through the Skills CLI and make it visible to skills.sh telemetry, use:
npx skills add gadicc/yahoo-finance2
Related skills
Generative Code Art
anthropics
Create algorithmic art with p5.js using randomness and interactive parameters.
Poster & Visual Design
anthropics
Create original posters and visual art in PNG and PDF formats.
Claude API Helper
anthropics
Build, debug, and optimize Claude API applications with caching and model migration support.
MCP Server Builder
anthropics
Build protocol servers that connect language models to external APIs and services.