Skip to main content

Transform a KiCad footprint into a OpenPnP package

Project description

kicad-to-openpnp

kicad-to-openpnp helps you convert your KiCad project into a set of full-fledged OpenPnP packages and parts, including pin definitions, as well as dimensions taken from 3D models of the footprints.

It does not replace OpenPnP's KiCad position file import process, it enhances it.

While this project is still WIP, it's been used in several successful assemblies so far.

Installation

Using pipx (installation instructions) is recommended:

pipx install --system-site-packages kicad-to-openpnp

(--system-site-packages is required due to how KiCad distributes its Python bindings.)

Alternatively, for the latest of the latest, you can try installing directly from GitHub:

pipx install --system-site-packages git+https://github.com/mmalecki/kicad-to-openpnp.git

Usage

Assuming your board file is called board.kicad_pcb, and you're in your .openpnp2 directory, you can run the following two commands to generate your new packages.xml and parts.xml:

kicad-board-to-openpnp-packages --board board.kicad_pcb --join packages.xml > packages.new.xml
kicad-board-to-openpnp-parts --board board.kicad_pcb --join parts.xml > parts.new.xml

The --join option will preserve your previous packages and parts and add them without modification to your new files. An option to allow for updating old entities based on new findings is in the works.

Therefore, if you just want to look at what the tool would output for your current board only:

kicad-board-to-openpnp-packages --board board.kicad_pcb
kicad-board-to-openpnp-parts --board board.kicad_pcb

If the new package and part files look correct, and your OpenPnP application is closed, you can now move them in place of the old files (making backups beforehand, if you'd like):

mv packages.new.xml packages.xml
mv parts.new.xml parts.xml

Why and how?

I found inputting part heights, sizes and pads into OpenPnP to be a rather large time commitment, so I begun looking for ways to automate that.

I quickly realized that KiCad footprints don't actually contain part body size information.
However, manufacturers now happily publish STEP files of their products, and I'm yet to find a model which would be so wildly inaccurate that it would be a problem for PnP process (0.1 ~ 0.2 mm variations are typical, though).

I then used the KiCad Python bindings to read in the pads and 3D models from the footprints (accounting for rotation), and CadQuery to load the models and measure their bounding boxes. This turned out to work. I was able to run several PnP jobs using the data generated by these here scripts.

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_to_openpnp-0.2.0.tar.gz (6.8 kB view details)

Uploaded Source

Built Distribution

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

kicad_to_openpnp-0.2.0-py3-none-any.whl (10.4 kB view details)

Uploaded Python 3

File details

Details for the file kicad_to_openpnp-0.2.0.tar.gz.

File metadata

  • Download URL: kicad_to_openpnp-0.2.0.tar.gz
  • Upload date:
  • Size: 6.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.1 CPython/3.12.10 Linux/6.17.13+deb14-amd64

File hashes

Hashes for kicad_to_openpnp-0.2.0.tar.gz
Algorithm Hash digest
SHA256 ed938afb13d25ca58daa250b11ec17592db39792864c03649f3ab1cf655bde5d
MD5 1741600fe35e32a925a7804539c70859
BLAKE2b-256 f085a91c0afa96cb0d598ffa5b5b03a33f8c8d8f11519ddcb3868a244ebdb8f2

See more details on using hashes here.

File details

Details for the file kicad_to_openpnp-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: kicad_to_openpnp-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 10.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.0.1 CPython/3.12.10 Linux/6.17.13+deb14-amd64

File hashes

Hashes for kicad_to_openpnp-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 62e8f74955b5a2a5706bad8803cca8b377bd7e92b9e1a567d962c1f5f984839b
MD5 4b7a61e6b33ba22a02c95293fdf64998
BLAKE2b-256 505ce90dd3a774a3b4a8ee9b3e7553642219c0f2615701ad5e020ec83b2c0a71

See more details on using hashes here.

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