Skip to main content

MCP server for searching JLCPCB components with live stock and pricing

Project description

JLCPCB Search MCP Server

A Model Context Protocol (MCP) server that provides AI assistants with powerful search capabilities for JLCPCB's electronic component catalog. Search 450,000+ components with real-time stock levels and pricing.

PyPI version

Built on top of yaqwsx/jlcparts - huge thanks to Jan Mrazek for doing the hard work of downloading JLCPCB XLS sheets, converting them to structured JSON, and hosting them for the community!

Features

  • Fast Local Search: SQLite database with 450K+ components for instant searches
  • Live Data: Real-time stock levels and pricing from JLCPCB API
  • Smart Filtering: Filter by package type, category, Basic/Extended parts, minimum stock
  • Detailed Information: Full specifications, datasheets, pricing tiers, and images
  • Easy Integration: Works with Claude Desktop, VSCode, and any MCP-compatible client

Example Usage

Ask Claude natural questions about components:

You: "Can you find a good 10uF SMD capacitor that can support 10V or less?"

Claude's Response:

Based on my search, here are some good 10uF SMD capacitors that can support 10V or less:

Recommended Options (Aluminum Electrolytic SMD):

Best Choice - C4747968 (RST10UF16V013)

Alternative - C970654 (RVT1C100M0405)

All of these are aluminum electrolytic SMD capacitors rated for 16V, which gives you plenty of margin for a 10V application. The C4747968 is my top recommendation due to its excellent stock levels and lower price.

Note: These are all Extended parts (not Basic), so they will incur additional assembly fees if you're using JLCPCB assembly.

Tools

The MCP server exposes four tools to your AI assistant:

Tool What it does
search_components Keyword search across the catalog. Optional filters: category, package, basic_only, min_stock, max_results.
get_component_details Full live details for an LCSC part — current stock, pricing tiers, full parameter list, datasheet, and images.
database_status Reports the local database location, size, and component count.
refresh_database Re-downloads the catalog snapshot from inside the chat — no CLI needed.

Most of the time you don't call these directly; you ask Claude in natural language ("find me a 10k 0805 resistor with at least 5k in stock") and it picks the right tool.

Data Freshness

This server uses a hybrid approach — a local catalog snapshot for fast search, plus live API calls for stock and pricing.

Data Source Freshness
Component catalog (descriptions, packages, attributes, categories) Local SQLite, built from yaqwsx/jlcparts Snapshot from your last refresh
Stock levels Live JLCPCB API (wmsc.lcsc.com) Real-time, per query
Pricing tiers Live JLCPCB API Real-time, per query
Datasheet URL Live JLCPCB API Real-time, per query

The local catalog does not auto-update. Refresh it periodically to pick up newly-added parts, removed parts, and metadata changes:

jlcpcb-mcp-setup --refresh-db

For most workflows, refreshing weekly or monthly is sufficient. Stock and price decisions are always made against live data, so you don't need a fresh catalog to trust the numbers on parts you already know.

Installation

From PyPI

# Install for current user (recommended for Claude Desktop)
pip install --user jlcpcb-search-mcp

# Or use pipx for isolated installation (best for CLI tools)
pipx install jlcpcb-search-mcp

# Or install in a virtual environment
python -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate
pip install jlcpcb-search-mcp

# Or install with uv in a project (uv is my fav!)
uv add jlcpcb-search-mcp

From Source

git clone https://github.com/peterb154/jlcpcb-search-mcp.git
cd jlcpcb-search-mcp
pip install -e .

Important: When using Claude Code, the MCP server must be accessible from your project's environment:

  • For uv projects: Install with uv add jlcpcb-search-mcp and use uv run claude commands
  • For system-wide use: Install with pip install --user jlcpcb-search-mcp or pipx install jlcpcb-search-mcp
  • For venv projects: Install in your venv and activate it before starting your editor

Quick Start

Claude Code Configuration

Option 1: Automatic Setup (Recommended)

Use the setup utility to automatically configure the MCP server:

# For current workspace (creates .mcp.json)
# Uses shared database in user's application data directory - RECOMMENDED
jlcpcb-mcp-setup --workspace

# Or if using uv project
uv run jlcpcb-mcp-setup --workspace

# For development of THIS package only (uses ./data/ directory)
# This creates a separate 900MB+ database in your project - avoid unless needed
jlcpcb-mcp-setup --workspace --dev

# Globally for Claude Desktop (also uses shared database)
jlcpcb-mcp-setup --global

After running the setup:

  1. Reload your editor window (Cmd+Shift+P → Developer: Reload Window)

  2. Check that the MCP server is connected:

    # If using uv project:
    uv run claude mcp list
    

    should return something like the following - notice that the mcp server is connected:

    Checking MCP server health...
    
    jlcpcb-search: jlcpcb-mcp  - ✓ Connected
    
    # Otherwise if not using uv:
    claude mcp list
    
  3. You should see: jlcpcb-search: jlcpcb-mcp - ✓ Connected

  4. Start searching for components!

Option 2: Manual Configuration

Create .mcp.json in your workspace root:

{
  "mcpServers": {
    "jlcpcb-search": {
      "command": "jlcpcb-mcp"
    }
  }
}

Or for global configuration in Claude Desktop:

macOS: ~/Library/Application Support/Claude/mcp.json Windows: %APPDATA%\Claude\mcp.json Linux: ~/.config/claude/mcp.json

Note for uv projects: The same simple config works! When you run uv run claude, it automatically uses the environment where jlcpcb-mcp is installed. No special configuration needed.

First Run & Database Setup

The database will be automatically built on your first component search. However, you can pre-download it to avoid waiting:

# Pre-download the database (recommended)
jlcpcb-mcp-setup --refresh-db

# Or with uv
uv run jlcpcb-mcp-setup --refresh-db

What to expect:

  • Download: ~50MB compressed (manifest + attributes lookup table + ~1,294 per-subcategory shards)
  • Final size: ~1.8GB SQLite database uncompressed (~576k components, 1,289 subcategories)
  • Time: ~4 minutes on fast internet connection (500Mbps), up to 10 minutes on slower connections
  • Progress: Real-time updates showing download progress and subcategory processing

If you don't pre-download, your first Claude query will trigger the download automatically, so expect a 3-10 minute wait.

Database Location

The database is shared across all your projects by default (recommended):

  • macOS: ~/Library/Application Support/jlcpcb-mcp/components.sqlite
  • Linux: ~/.local/share/jlcpcb-mcp/components.sqlite
  • Windows: %LOCALAPPDATA%\jlcpcb-mcp\components.sqlite

Why shared?

  • One 900MB database serves all your projects
  • Saves disk space
  • Faster setup for new projects
  • Easier to keep updated

Dev mode (--dev): Only use this if you're developing the jlcpcb-mcp package itself. It creates a separate database in ./data/ which is useful for testing but wastes space for normal usage.

License

MIT License - see LICENSE file for details

Acknowledgments

Support

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

jlcpcb_search_mcp-1.2.0.tar.gz (20.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

jlcpcb_search_mcp-1.2.0-py3-none-any.whl (21.3 kB view details)

Uploaded Python 3

File details

Details for the file jlcpcb_search_mcp-1.2.0.tar.gz.

File metadata

  • Download URL: jlcpcb_search_mcp-1.2.0.tar.gz
  • Upload date:
  • Size: 20.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for jlcpcb_search_mcp-1.2.0.tar.gz
Algorithm Hash digest
SHA256 47aa3b11e46b243eb5146e50e5589641a29bc4103efe9a5ff9b2e451feb6a990
MD5 768b8ab3873fb62bed4a6f4ae6ea9784
BLAKE2b-256 65adf2f1afbc42e67fac6c78e833d6891e5616091ba3779d094ccef8ae81af0a

See more details on using hashes here.

Provenance

The following attestation bundles were made for jlcpcb_search_mcp-1.2.0.tar.gz:

Publisher: publish.yaml on peterb154/jlcpcb-search-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file jlcpcb_search_mcp-1.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for jlcpcb_search_mcp-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 49862a760af10108c0f4fdac2903c1cf4e241ecdc4931c7ae4e6c1fd79f3331a
MD5 d51487b51d7767d3e774e24dc93c7772
BLAKE2b-256 1944215cd65d3c0f37e436d21e3451620adc7c1fbc28a5c763b718a5756fe9ea

See more details on using hashes here.

Provenance

The following attestation bundles were made for jlcpcb_search_mcp-1.2.0-py3-none-any.whl:

Publisher: publish.yaml on peterb154/jlcpcb-search-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page