Skip to main content

Python library for automated DXF file marking and manipulation to engrave your cut files

Project description

SnapMark

SnapMark is a Python library for applying intelligent, customizable text markings and engraving paths on DXF (AutoCAD) files. It is designed to generate laser-engraving traces (not cutting paths) that make each part identifiable through incised labels, codes, and metadata. Built on top of the excellent ezdxf, it provides a simple API for marking, alignment, hole analysis, and batch processing — tailored for manufacturing, CNC workflows, and automated drawing preparation.

PyPI version Python 3.8+ License: MIT


⚠️ Unit & Scale Notice

SnapMark is designed for sheet-metal parts measured in millimeters.

Since DXF files may contain arbitrary units (meters, inches, kilometers, or undefined scale), loading a drawing in a different unit system may produce text markings that appear extremely large, extremely small, or misplaced.

If your DXF is not in millimeters, you must rescale it before processing, or the resulting engraving paths may not match the actual geometry.

⚠️ 3D Geometry Notice

SnapMark works exclusively with 2D DXF geometry. If the drawing contains 3D entities (non-zero Z values, 3D polylines, meshes, solids, or blocks with elevation), SnapMark will refuse processing to avoid unpredictable text placement.

Please ensure your DXF is flattened before use.


Installation

pip install snapmark

Quick Start

import snapmark as sm

# Mark all DXF files with their filename
sm.mark_by_name("path/to/drawings")

# Custom sequence: filename + folder name
seq = (sm.SequenceBuilder()
       .file_name()
       .folder(num_chars=2)   # firts 2 chars of folder name
       .build())

sm.mark_with_sequence("path/to/drawings", seq, scale_factor=100)

Features

  • Simple API - Mark files in a single function call
  • Custom sequences - Combine filename parts, folder names, literals, and custom logic
  • Automatic Alignment - Normalize orientation before marking
  • Batch Processing - Process folders and subfolders with IterationManager
  • Backup System - Automatic .bak creation and restoration
  • Hole Utilities - Fast hole detection and counting for quality checks
  • Extensible Architecture - Add your own operations and processing steps

Use Cases

  • Manufacturing: Add part numbers and quantities to production drawings
  • CAM workflows: Automatically mark drawings before CNC processing
  • Quality control: Count holes and verify drawing specifications
  • Batch processing: Apply consistent markings across large drawing sets

API Overview (Essentials)

Shortcuts (Simple Usage)

  • mark_by_name(folder) - Mark with filename
  • mark_by_splitted_text(folder, separator, part_index) - Mark with filename part
  • mark_with_sequence(folder, sequence) - Mark with custom sequence
  • quick_count_holes(folder, min_diam, max_diam) - Count holes
  • restore_backup(folder) - Restore from backups
  • process_single_file(file, *operations) - Pipeline on single file

SequenceBuilder (core)

seq = (sm.SequenceBuilder()
       .file_name()
       .file_part(separator="_", index=0)
       .folder(num_chars=2)
       .literal("TEXT")
       .custom(lambda folder, file: "X")
       .set_separator("-")
       .build())

Operations (Advanced)

  • AddMark(sequence) - Add text marking
  • Aligner() - Aligns the drawing along its longest side in the X direction.
  • CountHoles(find_func) - Count circles
  • AddX(find_func, x_size) - Add X marks
  • RemoveCircle(find_func) - Remove circles
  • SubstituteCircle(find_func, new_radius) - Replace circles

📘 Documentation: (Documentation files will be available in the docs/ directory.)

Requirements

  • Python 3.8+
  • ezdxf >= 1.0.0

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

MIT License - see LICENSE file for details.

Author

Federico Sidraschi
LinkedIn | GitHub

Acknowledgments

Built with ezdxf - the excellent DXF library for Python.

Examples

SnapMark comes with a set of ready-to-run examples located in the examples/ folder.
These examples demonstrate common operations, including restoring backups, counting holes, and basic marking.


Keywords: DXF, CAD, AutoCAD, marking, automation, batch processing, manufacturing, CNC, CAM

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

snapmark-2.0.6.tar.gz (34.7 kB view details)

Uploaded Source

Built Distribution

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

snapmark-2.0.6-py3-none-any.whl (38.1 kB view details)

Uploaded Python 3

File details

Details for the file snapmark-2.0.6.tar.gz.

File metadata

  • Download URL: snapmark-2.0.6.tar.gz
  • Upload date:
  • Size: 34.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.4

File hashes

Hashes for snapmark-2.0.6.tar.gz
Algorithm Hash digest
SHA256 b488da0690351e22ac884372f375e8d6ccc1d8711ec562309d8fa793995e3be3
MD5 51070b357db0706e17365961c1712cbd
BLAKE2b-256 f388decf9de1a00ccfcbb4922915fa7abadcdf8df6ea6ba87893a70a39358454

See more details on using hashes here.

File details

Details for the file snapmark-2.0.6-py3-none-any.whl.

File metadata

  • Download URL: snapmark-2.0.6-py3-none-any.whl
  • Upload date:
  • Size: 38.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.4

File hashes

Hashes for snapmark-2.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 090964a724fcbf055377cea3240f85b818508bb0b3f852363dd5884f9e9bb7a6
MD5 a563d063e39c705d6aa130f9e4c29270
BLAKE2b-256 6d13b5f2da999ad611f5487e6188262fa0c496c0daa06f8d5e27520de649a195

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