A comprehensive Python library for parsing and manipulating KiCad file formats
Project description
KiCadFiles
A comprehensive Python library for parsing and manipulating KiCad file formats.
📚 View Full Documentation - Complete API reference and examples
Features
- Complete KiCad S-expression support: >200 classes representing KiCad tokens (missing tokens? create an issue with examples)
- Type-safe parsing: Full Python type hints for all classes and methods
- Flexible error handling: Three strictness modes (STRICT, FAILSAFE, SILENT)
- Round-trip parsing: Parse KiCad files and convert back to S-expressions
- Minimal dependencies: Self-contained S-expression parsing (no external dependencies)
- Extensive testing: Comprehensive test suite ensuring reliability
Installation
pip install kicadfiles
Quick Start
Main File Format Classes
from kicadfiles import (
KicadPcb, KicadSch, Footprint, KicadWks, KicadSymbolLib,
KicadProject, KiCadDesignRules, FpLibTable, SymLibTable,
KiCadTemplates
)
# PCB board (.kicad_pcb)
pcb = KicadPcb.from_file("board.kicad_pcb")
# pcb.save_to_file("output.kicad_pcb")
# Schematic (.kicad_sch)
schematic = KicadSch.from_file("schematic.kicad_sch")
# schematic.save_to_file("output.kicad_sch")
# Footprint (.kicad_mod)
footprint = Footprint.from_file("component.kicad_mod")
# footprint.save_to_file("output.kicad_mod")
# Symbol library (.kicad_sym)
symbol_lib = KicadSymbolLib.from_file("library.kicad_sym")
# symbol_lib.save_to_file("output.kicad_sym")
# Worksheet (.kicad_wks)
worksheet = KicadWks.from_file("template.kicad_wks")
# worksheet.save_to_file("output.kicad_wks")
# Project settings (.kicad_pro)
project = KicadProject.from_file("project.kicad_pro")
# project.save_to_file("output.kicad_pro")
# Design rules (.kicad_dru)
design_rules = KiCadDesignRules.from_file("rules.kicad_dru")
# design_rules.save_to_file("output.kicad_dru")
# Footprint library table
fp_lib_table = FpLibTable.from_file("fp-lib-table")
# fp_lib_table.save_to_file("output-fp-lib-table")
# Symbol library table
sym_lib_table = SymLibTable.from_file("sym-lib-table")
# sym_lib_table.save_to_file("output-sym-lib-table")
Working with PCB Files
from kicadfiles import KicadPcb, KiCadTemplates, NamedFloat
# Load and modify existing PCB
pcb = KicadPcb.from_file("board.kicad_pcb")
# Access elements
for footprint in pcb.footprints:
print(f"Footprint: {footprint.library_link} at ({footprint.at.x}, {footprint.at.y})")
# Create new PCB from template
new_pcb = KiCadTemplates.pcb()
new_pcb.setup.pad_to_mask_clearance = NamedFloat("pad_to_mask_clearance", 0.05)
new_pcb.save_to_file("new_board.kicad_pcb")
API Overview
Core Classes
- NamedObject: Base class for all KiCad objects
- ParseStrictness: Enum controlling error handling (STRICT, FAILSAFE, SILENT)
Main File Format Classes
These classes represent complete KiCad file formats and support both from_file() and save_to_file() methods:
- KicadSymbolLib: Symbol library files (.kicad_sym)
- KicadPcb: PCB board files (.kicad_pcb)
- KicadSch: Schematic files (.kicad_sch)
- KicadWks: Worksheet files (.kicad_wks)
- Footprint: Individual footprint files (.kicad_mod)
- KicadProject: Project settings files (.kicad_pro)
Main Object Categories
- Base Types: At, Size, Layer, Stroke, etc.
- Text and Documents: TitleBlock, Page, Comment, etc.
- Pad and Drill: Pad, Drill, Via, etc.
- Graphics: Line, Circle, Arc, Polygon, etc.
- Symbol Library: Symbol, Pin, Property, etc.
- Footprint Library: Footprint, Model, Tags, etc.
- Zone System: Zone, Hatch, FilledPolygon, etc.
- Board Layout: General, Layers, Nets, etc.
- Schematic System: Wire, Junction, Label, etc.
Error Handling with Strictness Modes
from kicadfiles import At, ParseStrictness
# STRICT mode: Raises exceptions for any parsing errors
try:
at_obj = At.from_sexpr("(at 10.0 20.0)", ParseStrictness.STRICT)
except ValueError as e:
print(f"Parsing failed: {e}")
# FAILSAFE mode: Logs warnings and uses defaults for missing fields
at_obj = At.from_sexpr("(at 10.0 20.0)", ParseStrictness.FAILSAFE)
print(f"Angle defaulted to: {at_obj.angle}") # Output: 0.0
# SILENT mode: Silently uses defaults for missing fields
at_obj = At.from_sexpr("(at 10.0 20.0)", ParseStrictness.SILENT)
| Mode | Behavior |
|---|---|
| STRICT | Raises ValueError on errors |
| FAILSAFE | Logs warnings, uses defaults |
| SILENT | Uses defaults silently |
For a complete overview of all classes and their module organization, see kicadfiles/CLASSES.md.
Development
Setting up Development Environment
git clone https://github.com/Steffen-W/KiCadFiles.git
cd KiCadFiles
pip install -e ".[dev]"
Running Tests
pytest tests/ -v
Code Quality
# Format code
black .
isort .
# Linting
flake8 kicadfiles/
# Type checking
mypy kicadfiles/
pyright kicadfiles/
Documentation with sphinx
cd docs && make clean && make html && cd ..
# Open docs/build/html/index.html in browser
Coverage
pytest --cov=kicadfiles --cov-report=html tests/
# Open htmlcov/index.html in browser
License
This project is licensed under the MIT License - see the LICENSE file for details.
Support
If you encounter any problems or have questions, please open an issue on the GitHub repository.
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 kicadfiles-1.0.5.tar.gz.
File metadata
- Download URL: kicadfiles-1.0.5.tar.gz
- Upload date:
- Size: 106.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3417c7d94248e63bb464025cd04bda89619ad75a4fae2c079388059ea57838a7
|
|
| MD5 |
d09750ec17872e543e56faa60240b340
|
|
| BLAKE2b-256 |
5dc4ec875a8b771a3da60350392629e91df5ab51e8afb9c4aa74aa508bd33eca
|
Provenance
The following attestation bundles were made for kicadfiles-1.0.5.tar.gz:
Publisher:
publish.yml on Steffen-W/KiCadFiles
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
kicadfiles-1.0.5.tar.gz -
Subject digest:
3417c7d94248e63bb464025cd04bda89619ad75a4fae2c079388059ea57838a7 - Sigstore transparency entry: 585893268
- Sigstore integration time:
-
Permalink:
Steffen-W/KiCadFiles@ee1780bd523d2b8df360484e40fcad7770a8c552 -
Branch / Tag:
refs/heads/master - Owner: https://github.com/Steffen-W
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@ee1780bd523d2b8df360484e40fcad7770a8c552 -
Trigger Event:
workflow_dispatch
-
Statement type:
File details
Details for the file kicadfiles-1.0.5-py3-none-any.whl.
File metadata
- Download URL: kicadfiles-1.0.5-py3-none-any.whl
- Upload date:
- Size: 85.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8e8574cc68a98c3156d3ecac2c913a2e0089133b471242321ce82a9e755999ac
|
|
| MD5 |
feca30d4aabfef18e6aedf8ba5fc0630
|
|
| BLAKE2b-256 |
79bac09f98898e01b48e17e4b993522f128469e0e2575b2569d504ef91005d9e
|
Provenance
The following attestation bundles were made for kicadfiles-1.0.5-py3-none-any.whl:
Publisher:
publish.yml on Steffen-W/KiCadFiles
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
kicadfiles-1.0.5-py3-none-any.whl -
Subject digest:
8e8574cc68a98c3156d3ecac2c913a2e0089133b471242321ce82a9e755999ac - Sigstore transparency entry: 585893276
- Sigstore integration time:
-
Permalink:
Steffen-W/KiCadFiles@ee1780bd523d2b8df360484e40fcad7770a8c552 -
Branch / Tag:
refs/heads/master - Owner: https://github.com/Steffen-W
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@ee1780bd523d2b8df360484e40fcad7770a8c552 -
Trigger Event:
workflow_dispatch
-
Statement type: