Skip to main content

Scripts, templates, and examples for managing KiCad projects.

Project description

Welcome to kicad-helpers

Scripts, templates, and examples for managing KiCad projects

Build, Test, Package PyPI version shields.io

Project goals

  • provide a sensible default structure and scripts for managing KiCad projects
  • automate everything that can be automated with continuous integrations scripts (e.g., update BOMs, produce manufacturing files, run tests, generate documentation, etc.)
  • configure git and KiCad to play nicely together
  • support customization via command line arguments, environment variables, etc.
  • make everything easy to install/setup/use
  • make awesome documentation

Install

> pip install kicad_helpers

Setup a new project

Open a command line shell and navigate to the directory containing your KiCad project. Then run kh_update to apply various project templates to the project directory:

> cd kicad/project/path
> kh_update

By default, this will install the following templates:

To overwrite existing templates, run kh_update with the --overwrite flag:

> kh_update --v --overwrite
Render kitspace.yaml template.
Render settings.ini template.
Render .github/workflows/build.yml template.
Render .kicad_helpers_config/drc.yaml template.
Render .kicad_helpers_config/erc.yaml template.
Render .kicad_helpers_config/pcb_pdf.yaml template.
Render .kicad_helpers_config/pcb_svg.yaml template.
Render .kicad_helpers_config/sch_pdf.yaml template.
Render .kicad_helpers_config/sch_svg.yaml template.
Render .kicad_helpers_config/manufacturers/default.yaml template.
Render .kicad_helpers_config/manufacturers/PCBWay.yaml template.
Render tests/Tests.ipynb template.
"*.pro filter=kicad_project" already exists in /home/ryan/dev/python/kicad-helpers/_temp/.gitattributes
"*.sch filter=kicad_sch" already exists in /home/ryan/dev/python/kicad-helpers/_temp/.gitattributes
Add filters to git config.
"_autosave*" already exists in /home/ryan/dev/python/kicad-helpers/_temp/.gitignore
"*bak" already exists in /home/ryan/dev/python/kicad-helpers/_temp/.gitignore
"*.xml" already exists in /home/ryan/dev/python/kicad-helpers/_temp/.gitignore
".ipynb_checkpoints" already exists in /home/ryan/dev/python/kicad-helpers/_temp/.gitignore
"*-erc.txt" already exists in /home/ryan/dev/python/kicad-helpers/_temp/.gitignore
"*-drc.txt" already exists in /home/ryan/dev/python/kicad-helpers/_temp/.gitignore
"kibot_errors.filter" already exists in /home/ryan/dev/python/kicad-helpers/_temp/.gitignore

To see the options that are available, run the command:

> kh_update --help
usage: kh_update [-h] [--v] [--overwrite] [--root ROOT]

Setup a new project (or update an existing project) with templates from the `kicad_helpers/templates` directory. Also
installs git filters to prevent insignificant changes to the kicad `*.pro` and `*.sch` files from being tracked by git
(see https://jnavila.github.io/plotkicadsch/ for more details).

optional arguments:
  -h, --help   show this help message and exit
  --v          verbose (default: False)
  --overwrite  overwrite existing templates (default: False)
  --root ROOT  project root directory (default: .)

Export a BOM from the KiCad schematic

> kh_sch_to_bom --v
/home/ryan/miniconda3/envs/kh/bin/python3.9 -m kifield -r --nobackup --overwrite --group -aq -x /home/ryan/dev/python/kicad-helpers/_temp/40-channel-hv-switching-board.sch -i /home/ryan/dev/python/kicad-helpers/_temp/manufacturing/default/40-channel-hv-switching-board-BOM.csv

Import data from the BOM into the KiCad schematic

> kh_sch_to_bom --v
/home/ryan/miniconda3/envs/kh/bin/python3.9 -m kifield -r --nobackup --overwrite --fields ~quantity -x /home/ryan/dev/python/kicad-helpers/_temp/manufacturing/default/40-channel-hv-switching-board-BOM.csv -i /home/ryan/dev/python/kicad-helpers/_temp/40-channel-hv-switching-board.sch

Run all tests in the tests directory

> kh_test
testing /home/ryan/dev/python/kicad-helpers/_temp/tests/Tests.ipynb
All tests are passing!

Contributors

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

kicad_helpers-0.14.tar.gz (26.6 kB view details)

Uploaded Source

Built Distribution

kicad_helpers-0.14-py3-none-any.whl (27.1 kB view details)

Uploaded Python 3

File details

Details for the file kicad_helpers-0.14.tar.gz.

File metadata

  • Download URL: kicad_helpers-0.14.tar.gz
  • Upload date:
  • Size: 26.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.6.0 importlib_metadata/4.8.2 pkginfo/1.8.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.12

File hashes

Hashes for kicad_helpers-0.14.tar.gz
Algorithm Hash digest
SHA256 53f50590338e01c2eafbce0ff250cdcf3596eda54c3314c00886080e175e65a8
MD5 7bb43d25b3556c708a850b8f9f9c1471
BLAKE2b-256 4b892d99511cba11238e6ea238daf8c92df94ef56e8aae7a2ad9194bb03e2c1f

See more details on using hashes here.

File details

Details for the file kicad_helpers-0.14-py3-none-any.whl.

File metadata

  • Download URL: kicad_helpers-0.14-py3-none-any.whl
  • Upload date:
  • Size: 27.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.6.0 importlib_metadata/4.8.2 pkginfo/1.8.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.12

File hashes

Hashes for kicad_helpers-0.14-py3-none-any.whl
Algorithm Hash digest
SHA256 ab71dadd3e763fc721f60bea5c41ae79af26d66ab9fc1c0517cbfd554582efd2
MD5 c53b86da2d682fd73446b35031521bb0
BLAKE2b-256 563a68db0561d3d952ca62ca458f06e6e3e4ba65e0a25aee04e9a2ca5581053c

See more details on using hashes here.

Supported by

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