Skip to main content

A toolkit for manipulating Altium files

Project description

altium-monkey

          ▓▓▓▓▓▓▓▓▓▓
        ▓▓▓▓▓▓▓▓▓▓▓▓▓▓
      ▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓
    ▓▓▓▓░░░░░░▓▓░░░░░░▓▓▓▓
░░░░▓▓░░░░░░░░░░░░░░░░░░▓▓░░░░
░░░░▓▓░░    ░░░░░░    ░░▓▓░░░░
  ░░▓▓░░██  ░░░░░░██  ░░▓▓░░
    ▓▓░░░░░░░░░░░░░░░░░░▓▓
      ▓▓░░░░░░░░░░░░░░▓▓
        ▓▓▓▓░░░░░░▓▓▓▓
            ▓▓▓▓▓▓        ░░
          ▓▓▓▓▓▓▓▓▓▓      ▓▓
          ▓▓▓▓▓▓▓▓▓▓    ▓▓▓▓
        ▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓▓
        ▓▓▓▓░░▓▓░░▓▓▓▓

altium-monkey is a Python toolkit for reading, writing, analyzing, and rendering Altium files directly from automation.

It is designed for engineers who want to build their own command-line tools, CI/CD checks, visualization pipelines, library generators, BOM workflows, and design-review helpers without driving the Altium GUI for every operation.

What It Supports

Core file types:

  1. .SchDoc
  2. .SchLib
  3. .PcbDoc
  4. .PcbLib
  5. .PrjPcb
  6. .OutJob
  7. .IntLib extraction
  8. .PCBDwf Draftsman files, currently experimental

Common workflows:

  1. create and mutate schematic documents
  2. create schematic symbols and PCB footprints
  3. insert SchLib symbols and PcbLib footprints
  4. extract SchLib and PcbLib data from projects
  5. render schematic and PCB SVGs
  6. inspect PCB layers, drills, board outlines, nets, and net classes
  7. author and mutate PCB vias, including IPC-4761 protection metadata
  8. extract embedded fonts and 3D models
  9. generate project containers and run associated OutJobs
  10. create experimental Draftsman pages with notes, text, pictures, and generated board-assembly-view highlight artwork

Install

Python 3.11 and Python 3.12 are supported for this release.

pip install altium-monkey

or with uv:

uv add altium-monkey

For running the examples, prefer uv run .... It is the highest-probability path for using the expected interpreter and dependencies without local environment drift.

The package includes dependencies for SVG text shaping and STEP-model bounds. STEP bounds use wn-geometer, with published wheels currently available for Windows amd64, macOS arm64, and Linux x86_64 tagged manylinux_2_39. See RELEASE_NOTES.md for platform and Python-version boundaries. The CadQuery dependency is only needed for the public example that synthesizes new STEP models.

Public API Compatibility

We strive to maintain compatibility for documented public APIs between releases. The API surface may still change as more Altium capabilities are modeled, especially in areas that are currently marked as release boundaries or advanced usage. Compatibility-affecting changes and migration notes will be documented in release notes.

Quick Start

Parse a project and emit the public design JSON contract:

from altium_monkey import AltiumDesign

design = AltiumDesign.from_prjpcb("example.PrjPcb")
payload = design.to_json()

Create or modify a schematic, then save it:

from altium_monkey import AltiumSchDoc, SchFontSpec, SchRectMils, make_sch_note

schdoc = AltiumSchDoc("input.SchDoc")
note = make_sch_note(
    bounds_mils=SchRectMils.from_corners_mils(1000, 3000, 2600, 2400),
    text="Added by altium-monkey",
    font=SchFontSpec(name="Arial", size=10),
)
schdoc.add_object(note)
schdoc.save("output.SchDoc")

Create a simple PCB primitive:

from altium_monkey import AltiumPcbDoc, PcbLayer

pcbdoc = AltiumPcbDoc()
pcbdoc.add_track(
    (1000, 1000),
    (2500, 1000),
    width_mils=8,
    layer=PcbLayer.TOP,
    net="GND",
)
pcbdoc.save("output.PcbDoc")

Documentation

The public docs are Markdown-first for this release:

  1. SchDoc
  2. SchLib
  3. PcbDoc
  4. PcbLib
  5. PrjPcb
  6. AltiumDesign
  7. IntLib
  8. API patterns
  9. Schema contracts
  10. Format contracts
  11. Examples

The examples are the best starting point for public API usage. They are kept in examples/ and are indexed from examples/manifest.toml.

Contributing

This repository is a published mirror. Issues, minimal reproduction cases, documentation fixes, API feedback, and focused pull requests are welcome, but PRs may be adapted or reimplemented in the upstream development workspace before they are mirrored back here. See CONTRIBUTING.md.

API Shape

The schematic side uses a higher-level object system:

  1. AltiumSchDoc and AltiumSymbol own ObjectCollection instances.
  2. Typed views such as schdoc.notes and symbol.pins are live query views.
  3. Structural mutations should go through add_object(...), insert_object(...), or remove_object(...).

The PCB document side is helper-oriented rather than ObjectCollection-based:

  1. AltiumPcbDoc and AltiumPcbFootprint expose high-level add_* methods.
  2. AltiumPcbDoc covers common authoring workflows including board setup, nets, primitives, components, footprint insertion, component bodies, and embedded 3D model placement. Via support includes IPC-4761 type metadata, feature rows, propagation delay, tenting, and testpoint flags.
  3. Parsed primitives are available through typed record lists such as pcbdoc.tracks, pcbdoc.pads, pcbdoc.vias, and pcbdoc.components.
  4. Direct record-list mutation is possible but should be treated as advanced usage until PcbDoc grows a generic object API.

See API patterns for units, object ownership, public vs careful APIs, and internal Altium unit guidance.

Testing And Interoperability

altium-monkey is developed against a large private corpus and real-world Altium files spanning multiple Altium eras from "Summer '08" until present day. Interoperability checks include round-trip parsing, binary serialization, SVG rendering, and native Altium oracle comparisons where practical. The test corpus is not included in the public package.

No tool can prove perfect compatibility with every historical Altium file. If you find a parsing, serialization, SVG, or interoperability issue, please file an issue with the smallest representative .SchDoc, .SchLib, .PcbDoc, or .PcbLib that reproduces the problem.

Release Boundaries

Known release boundaries include:

  1. PcbDoc does not yet use ObjectCollection; it remains a typed-list plus helper-oriented API.
  2. PcbDoc does not yet have a public generic object deletion API.
  3. IntLib support is extract-only, with fallback source-stream extraction when component cross-reference metadata cannot be parsed.
  4. Variant processing supports DNP handling and parameter overrides; alternate fitted component replacement is not applied semantically yet.
  5. Complex hierarchical channels and .Annotation file handling may need additional validation.
  6. Windows remains the primary validation platform. Basic macOS operation and baseline font substitution have been checked; Linux coverage remains limited.

See RELEASE_NOTES.md for the full current support boundary.

License

altium-monkey is licensed under the GNU Affero General Public License v3.0 or later. See LICENSE.

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

altium_monkey-2026.6.8.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

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

altium_monkey-2026.6.8-py3-none-any.whl (1.2 MB view details)

Uploaded Python 3

File details

Details for the file altium_monkey-2026.6.8.tar.gz.

File metadata

  • Download URL: altium_monkey-2026.6.8.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for altium_monkey-2026.6.8.tar.gz
Algorithm Hash digest
SHA256 67a4ba513000b9409928dd6b5a2209c98c9c82049d7f973d5f3c1aaeb5914b07
MD5 be8df5a77a316c54c2d411f7ef40a5bd
BLAKE2b-256 00cfa5749f0bb3b521c57c18b9f376f77e76689930923735313902e893fa3acd

See more details on using hashes here.

Provenance

The following attestation bundles were made for altium_monkey-2026.6.8.tar.gz:

Publisher: release.yml on wavenumber-eng/altium_monkey

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

File details

Details for the file altium_monkey-2026.6.8-py3-none-any.whl.

File metadata

File hashes

Hashes for altium_monkey-2026.6.8-py3-none-any.whl
Algorithm Hash digest
SHA256 18b254700c3460a7be5ae60404a174eae3dbcdd34ca772e99a5f88a543f7ad1a
MD5 6cb8de115c3675c3f5c347081a9191b5
BLAKE2b-256 614cf42b4ae45d1052b4935179ac48d5c251022c7971acbb238b3571f8828c3c

See more details on using hashes here.

Provenance

The following attestation bundles were made for altium_monkey-2026.6.8-py3-none-any.whl:

Publisher: release.yml on wavenumber-eng/altium_monkey

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