Gives Claude structured access to electronic component datasheets without touching PDFs. You can search parts, pull pinouts and electrical specs on demand, validate design parameters against abs max ratings, compare alternatives, and even upload private datasheets for extraction. The compare_parts and check_design_fit tools are especially useful during component selection when you need to verify operating conditions or find drop-in replacements. Ships with prompts for common workflows like BOM review and thermal analysis. Supports OAuth and API key auth, works over stdio or HTTP. Built for hardware engineers who want agents to reason about real component data instead of hallucinating specs or choking on 200-page PDFs.
claude mcp add --transport http sheetsdata-mcp https://mcp.sheetsdata.com/mcpRun in your terminal. Add --scope user to make it available in every project.
Review the command, arguments, and environment values before installing — MCP servers run with your local permissions.
Verified live against the running server on Jun 10, 2026.
search_partsSearch for electronic components by part number, description, or keyword. Start here — this is the best entry point for finding components. Queries all configured providers in parallel. Results are merged by MPN with indicative pricing and stock from each source. Each result i...3 paramsSearch for electronic components by part number, description, or keyword. Start here — this is the best entry point for finding components. Queries all configured providers in parallel. Results are merged by MPN with indicative pricing and stock from each source. Each result i...
limitintegerquery*stringprovidersstringall · jlcpcb · mouser · digikeydefault: allsearch_datasheetsSemantic search across all extracted datasheets. Finds components matching natural language queries about specifications, features, or capabilities. Best for broad spec-based discovery across all parts (e.g. 'low-noise LDO with PSRR above 70dB'). Only searches datasheets that...3 paramsSemantic search across all extracted datasheets. Finds components matching natural language queries about specifications, features, or capabilities. Best for broad spec-based discovery across all parts (e.g. 'low-noise LDO with PSRR above 70dB'). Only searches datasheets that...
limitintegerquery*stringsection_typestringall · electrical_characteristics · features · description · pin_configuration · absolute_maximum_ratingsdefault: allprefetch_datasheetsTrigger background datasheet extraction for multiple parts at once (up to 20). Non-blocking — returns immediately with the status of each part. Use this to warm up datasheets for a BOM before calling read_datasheet. Example: prefetch_datasheets(['TPS54302', 'ADS1115', 'LP5907'...1 paramsTrigger background datasheet extraction for multiple parts at once (up to 20). Non-blocking — returns immediately with the status of each part. Use this to warm up datasheets for a BOM before calling read_datasheet. Example: prefetch_datasheets(['TPS54302', 'ADS1115', 'LP5907'...
part_numbers*arraycheck_extraction_statusCheck the extraction status of one or more parts. Free. Each entry includes the current extraction step, elapsed seconds, and document ID. Use after prefetch_datasheets or after read_datasheet triggers a new extraction. Recommended polling cadence: every 5-10 seconds. Extracti...1 paramsCheck the extraction status of one or more parts. Free. Each entry includes the current extraction step, elapsed seconds, and document ID. Use after prefetch_datasheets or after read_datasheet triggers a new extraction. Recommended polling cadence: every 5-10 seconds. Extracti...
part_numbers*arrayget_part_detailsGet full details for a specific electronic component by manufacturer part number (MPN) or LCSC number. Returns specs, pricing, and stock from all configured providers, plus the cached datasheet summary if available. Includes datasheet_status and available_sections when ready....3 paramsGet full details for a specific electronic component by manufacturer part number (MPN) or LCSC number. Returns specs, pricing, and stock from all configured providers, plus the cached datasheet summary if available. Includes datasheet_status and available_sections when ready....
providerstringall · jlcpcb · mouser · digikeydefault: allpart_number*stringprefetch_datasheetbooleanread_datasheetRead from a component's datasheet. Two modes: **Section mode** (default): Returns a named section. Start with section='summary' to get an overview and a list of available_sections. Then request specific sections by name. Section names are dynamic — any heading in the actual da...5 paramsRead from a component's datasheet. Two modes: **Section mode** (default): Returns a named section. Start with section='summary' to get an overview and a list of available_sections. Then request specific sections by name. Section names are dynamic — any heading in the actual da...
modestringsection · searchdefault: sectionlimitintegerquerystringsectionstringpart_number*stringcompare_partsCompare 2-5 electronic components side by side in a single call. For each part, returns merged provider data (pricing, stock, structured parameters, package) plus the cached datasheet summary if one exists, plus datasheet_status ('ready', 'extracting', or 'not_extracted'). Use...1 paramsCompare 2-5 electronic components side by side in a single call. For each part, returns merged provider data (pricing, stock, structured parameters, package) plus the cached datasheet summary if one exists, plus datasheet_status ('ready', 'extracting', or 'not_extracted'). Use...
part_numbers*arraycheck_design_fitValidate whether a component will work within your operating conditions. Compares your design parameters against the datasheet's absolute maximum ratings and recommended operating conditions. Returns PASS/FAIL/WARNING per parameter with margin percentages. Parameter mapping by...7 paramsValidate whether a component will work within your operating conditions. Compares your design parameters against the datasheet's absolute maximum ratings and recommended operating conditions. Returns PASS/FAIL/WARNING per parameter with margin percentages. Parameter mapping by...
part_number*stringambient_tempnumberinput_voltagenumberoutput_currentnumberoutput_voltagenumbersupply_voltagenumberswitching_frequencynumberanalyze_imageAnalyze an image from a component's datasheet using vision AI. Use this when read_datasheet returns a section containing images and you need to extract data from a graph, package drawing, pin diagram, or circuit schematic. Pass the image_key from the read_datasheet response (t...3 paramsAnalyze an image from a component's datasheet using vision AI. Use this when read_datasheet returns a section containing images and you need to extract data from a graph, package drawing, pin diagram, or circuit schematic. Pass the image_key from the read_datasheet response (t...
questionstringimage_key*stringpart_number*stringfind_alternativeFind alternative / second-source components for a given MPN. Returns parts ranked by how closely their specs, package, and category match the reference part, with a match_score and match_notes explaining each match. When to use: - Original part is out of stock or end-of-life....3 paramsFind alternative / second-source components for a given MPN. Returns parts ranked by how closely their specs, package, and category match the reference part, with a match_score and match_notes explaining each match. When to use: - Original part is out of stock or end-of-life....
limitintegerconstraintsarraypart_number*stringrequest_datasheet_uploadRequest a signed URL to upload a datasheet PDF for a component whose datasheet we don't have. Use this when search_parts / get_part_details / prefetch_datasheets return datasheet_status='no_source' (and a retry didn't help) or 'unsupported'. Free — the upload fee is only charg...4 paramsRequest a signed URL to upload a datasheet PDF for a component whose datasheet we don't have. Use this when search_parts / get_part_details / prefetch_datasheets return datasheet_status='no_source' (and a retry didn't help) or 'unsupported'. Free — the upload fee is only charg...
size_bytes*integerpart_number*stringmanufacturerstringexpected_sha256*stringconfirm_datasheet_uploadConfirm a datasheet upload started via request_datasheet_upload. Pass the upload_token you got back from the request step. The server downloads the uploaded bytes, re-hashes to verify integrity, validates that it's a real PDF with the MPN on the first page, creates the private...1 paramsConfirm a datasheet upload started via request_datasheet_upload. Pass the upload_token you got back from the request step. The server downloads the uploaded bytes, re-hashes to verify integrity, validates that it's a real PDF with the MPN on the first page, creates the private...
upload_token*stringElectronic component datasheets for AI agents — specs, pinouts, package data on demand. No PDFs required.
SheetsData is an MCP server that gives AI agents instant, structured access to electronic component data. One tool call returns the pinout. Another returns electrical specs. No PDFs. No uploads. No context window stuffing.
Beta — SheetsData is currently in public beta. APIs, pricing, and features may change. See Disclaimer below.
Sign up & connect via OAuth · API key (fallback) · Website
Agent: read_datasheet("TPS54302", section="pinout")
→ Pin table: BOOT(6), EN(5), FB(4), GND(1), SW(2), VIN(3)
Agent: check_design_fit("TPS54302", input_voltage=12, output_current=2)
→ PASS — all parameters within datasheet limits
Agent: "What's the maximum SPI clock frequency for the STM32G030?"
→ Uses read_datasheet to find electrical specs — returns 32 MHz
Agent: find_alternative("TPS54302", constraints="in_stock")
→ MP2315, TPS54331 ranked by package/spec match
The agent never sees a PDF. The engineer never uploads one.
| Tool | Description |
|---|---|
search_parts | Search for components by part number or keyword. Results merged by MPN with pricing and stock. |
search_datasheets | Semantic search across all extracted datasheets. Natural language queries like "low-noise LDO with PSRR above 70dB". |
prefetch_datasheets | Batch warm-up extraction for up to 20 parts. Fire-and-forget — reduces wait times. |
check_extraction_status | Poll extraction progress after prefetch or read_datasheet. |
get_part_details | Full component details — specs, parameters, pricing, and stock. |
read_datasheet | Structured datasheet sections (summary, pinout, electrical, abs_max, package) or semantic search within a datasheet. |
compare_parts | Compare 2–5 parts side by side on real datasheet specs. |
check_design_fit | Validate operating conditions against datasheet limits. PASS/FAIL/WARNING per parameter. |
find_alternative | Find alternative/substitute components by specs, package, or availability. |
analyze_image | Vision AI analysis of datasheet images — graphs, package drawings, pin diagrams. |
request_datasheet_upload | Request a signed URL to upload a datasheet PDF when we don't have one (datasheet_status = no_source or unsupported). Free — fee is only charged on confirm. |
confirm_datasheet_upload | Confirm an upload: verifies SHA-256, validates PDF, checks MPN on first page, charges the upload fee, and queues extraction. Datasheets are private to your org. |
Built-in prompt templates that guide the agent through common hardware engineering tasks:
| Prompt | Description |
|---|---|
component-selection | Walk through selecting a component: define requirements, search candidates, compare specs, validate design fit. |
bom-review | Review a bill of materials: look up each part, check stock and lifecycle, flag risks, suggest alternatives. |
datasheet-deep-dive | Deep-dive into a specific part: summarize, extract pinout, electrical specs, absolute max ratings, and application circuit. |
design-validation | Validate a design: check each component against operating conditions, flag out-of-spec parameters. |
second-source | Find second-source alternatives for a part: match package, specs, and availability across providers. |
interface-check | Check electrical and protocol compatibility between two ICs on a shared bus (SPI, I2C, UART). Verifies VOH/VOL vs VIH/VIL, flags level-shifter needs, extracts protocol config (SPI mode, I2C address, pull-up values). |
firmware-kickstart | Extract register map, init sequence, and protocol details from a peripheral IC datasheet. Generates a firmware integration guide with register writes, transaction examples, and common pitfalls. |
thermal-review | Thermal and derating analysis: compare operating conditions against abs max AND recommended limits, estimate junction temperature, check SOA derating curves, flag exposed-pad requirements. |
Data the server exposes for agent context:
| Resource | Description |
|---|---|
sheetsdata://workflow | Recommended tool workflow for component selection — search, evaluate, read datasheet, validate, compare. |
sheetsdata://tips/datasheet-pitfalls | The 8 most common datasheet interpretation mistakes — abs max confusion, typical vs worst-case, thermal derating, voltage levels, I2C/SPI gotchas, decoupling, exposed pads, lifecycle risks. |
sheetsdata://tips/design-review-checklist | Hardware design review checklist covering power supply, signal interfaces, component selection, and firmware integration. |
SheetsData supports two auth paths. Use whichever works best for your client; both bill against the same org.
| OAuth 2.0 | API key | |
|---|---|---|
| Best for | Interactive MCP clients (Claude Desktop, Cursor, etc.) | CI, scripts, headless agents, or clients that don't speak MCP OAuth |
| What you do | Click Connect in your client → log in here → done | Generate a key in the dashboard, paste as a Bearer header |
| Setup | Just paste a URL | Paste a URL + a header |
| Discovery | Automatic via RFC 8414 / RFC 9728 | n/a |
| Spec compliance | PKCE-mandatory, dynamic client registration (RFC 7591), refresh-token rotation | RFC 6750 Bearer |
| Revoke | Per-client, from /dashboard/keys | Delete the key |
Recommended: OAuth. It's a single URL paste, no copy-pasting secrets, and you can yank a connected app from the dashboard at any time.
Claude Desktop — download the .mcpb bundle from the latest GitHub release and drag-and-drop it into the Claude Desktop window. The install dialog will surface every tool the bundle provides before confirming. Leave the API key field blank to use OAuth (recommended) — Claude Desktop will open a browser tab on first use to authorize. No JSON editing.
Cursor or VS Code — single-click install pre-fills the config and prompts to authorize on first use.
For everything else, copy the snippet from the right section below.
Easiest — drag-and-drop the bundled extension. Download the latest sheetsdata-x.y.z.mcpb from the Releases page and drop the file onto the Claude Desktop window. Claude shows the list of tools the bundle provides and installs it. Leave the API key field blank to use OAuth (recommended) — a browser tab opens on first use to authorize. No JSON editing, no npm install.
Or — add a remote connector via the UI. Open Claude Desktop → Settings → Connectors → Add custom connector at the bottom of the list.
| Field | Value |
|---|---|
| Name | SheetsData |
| URL | https://mcp.sheetsdata.com/mcp |
Click Add. Claude Desktop will open a browser tab to the SheetsData consent screen — pick the org to authorize, and you're done. Tools appear in Claude immediately.
Note: The
claude_desktop_config.jsonfile does not support the OAuth flow on Claude Desktop. The Connectors UI is the right path for OAuth — only fall back to the JSON config if you want to use an API key instead.
Open Claude Desktop → Settings → Developer → Edit Config, then add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
{
"mcpServers": {
"sheetsdata": {
"url": "https://mcp.sheetsdata.com/mcp",
"headers": {
"Authorization": "Bearer YOUR_API_KEY"
}
}
}
}
Restart Claude Desktop. Get a key from sheetsdata.com/dashboard/keys.
claude mcp add sheetsdata --transport http "https://mcp.sheetsdata.com/mcp"
Claude Code will print a one-time OAuth URL — open it, authorize, done.
claude mcp add sheetsdata \
--transport http \
"https://mcp.sheetsdata.com/mcp" \
--header "Authorization: Bearer YOUR_API_KEY"
Click the Install in Cursor badge above, or add to .cursor/mcp.json:
{
"mcpServers": {
"sheetsdata": {
"url": "https://mcp.sheetsdata.com/mcp"
}
}
}
Restart Cursor → MCP panel → SheetsData → Connect.
{
"mcpServers": {
"sheetsdata": {
"url": "https://mcp.sheetsdata.com/mcp",
"headers": {
"Authorization": "Bearer YOUR_API_KEY"
}
}
}
}
Click the Install in VS Code badge above, or add to .vscode/mcp.json:
{
"servers": {
"sheetsdata": {
"type": "http",
"url": "https://mcp.sheetsdata.com/mcp"
}
}
}
VS Code will prompt you to authorize on first use.
{
"servers": {
"sheetsdata": {
"type": "http",
"url": "https://mcp.sheetsdata.com/mcp",
"headers": {
"Authorization": "Bearer YOUR_API_KEY"
}
}
}
}
Add to ~/.codeium/windsurf/mcp_config.json:
{
"mcpServers": {
"sheetsdata": {
"url": "https://mcp.sheetsdata.com/mcp"
}
}
}
Restart Windsurf and click Connect on the SheetsData entry.
{
"mcpServers": {
"sheetsdata": {
"url": "https://mcp.sheetsdata.com/mcp",
"headers": {
"Authorization": "Bearer YOUR_API_KEY"
}
}
}
}
Add to your Amp settings:
{
"amp.mcpServers": {
"sheetsdata": {
"url": "https://mcp.sheetsdata.com/mcp"
}
}
}
Amp will run the OAuth flow on first use.
{
"amp.mcpServers": {
"sheetsdata": {
"url": "https://mcp.sheetsdata.com/mcp",
"headers": {
"Authorization": "Bearer YOUR_API_KEY"
}
}
}
}
Cline doesn't yet support the MCP OAuth flow — use an API key.
In VS Code, open Cline → gear icon → MCP Servers:
{
"mcpServers": {
"sheetsdata": {
"url": "https://mcp.sheetsdata.com/mcp",
"headers": {
"Authorization": "Bearer YOUR_API_KEY"
},
"disabled": false
}
}
}
Zed doesn't yet support the MCP OAuth flow — use an API key.
Add to Zed settings.json:
{
"context_servers": {
"sheetsdata": {
"settings": {
"url": "https://mcp.sheetsdata.com/mcp",
"headers": {
"Authorization": "Bearer YOUR_API_KEY"
}
}
}
}
}
Continue doesn't yet support the MCP OAuth flow — use an API key.
Add to ~/.continue/config.yaml:
mcpServers:
- name: sheetsdata
url: https://mcp.sheetsdata.com/mcp
headers:
Authorization: "Bearer YOUR_API_KEY"
For clients that only support stdio transport:
SHEETSDATA_API_KEY=your_key npx @sheetsdata/mcp
You can also manage OAuth-authorized apps from the same page — see who has connected, when, and revoke any of them with one click.
1. search_parts → Find candidates by keyword or part number
2. get_part_details → Evaluate pricing, stock, parameters
3. read_datasheet → Get detailed specs (pinout, electrical, package)
4. check_design_fit → Validate against your operating conditions
5. find_alternative → Find substitutes if needed
6. compare_parts → Side-by-side comparison of finalists
SheetsData is currently in public beta. Data is extracted from publicly available manufacturer datasheets using automated tools including AI. It may contain errors, omissions, or inaccuracies.
SheetsData and Octoco Ltd provide this data on an "as is" basis and make no warranties, express or implied, regarding the accuracy, completeness, or fitness for any particular purpose. Always verify critical specifications against the official manufacturer datasheet before making design, purchasing, or manufacturing decisions.
By using this service, you acknowledge that:
For terms of use, see sheetsdata.com/terms.
MIT
SHEETSDATA_API_KEYsecretOptional — if omitted, OAuth login opens in your browser. Get a key at https://sheetsdata.com/dashboard/keys
com.mcparmory/google-sheets
domdomegg/google-sheets-mcp
henilcalagiya/google-sheets-mcp
cct15/war-dashboard-data
moooonad/mcp-google-sheets-full
io.github.br0ski777/csv-to-json