Unofficial Python wrapper for the TYCMA ICON Interface HTTP TCPIP API for laser marking systems.
Project description
pyiconlaser
Unofficial Python wrapper for the TYKMA ICON Interface HTTP/TCP API used by industrial laser marking systems.
This library provides a simple Python API for controlling compatible laser marking systems through the ICON Interface software.
This project is community-maintained and is not affiliated with or endorsed by any hardware manufacturer.
This library was developed and tested against TYKMA ICON Interface software based on available API documentation and observed real-world behavior.
Features
- Load marking jobs
- Read available IDs and modify their values
- Start and stop marking sequences
- Enable or clear jobs
- Control limits (tracing beam)
- Retrieve machine status
- Get template preview images
Requirements
This library requires the vendor software TYKMA ICON Interface to be installed and running on the target machine.
The HTTP/TCP API must also be enabled manually in the Config.xml configuration file.
Before using this library:
- Install TYKMA ICON Interface software
- Vendor contact may be required to obtain the software and API documentation
- Enable HTTP/TCP communication in
Config.xml - Verify the API is accessible (default port
5287) - Ensure the laser system is connected and recognized by ICON Interface
Installation
pip install pyiconlaser
Or install locally:
pip install .
Quick Start
from pyiconlaser import IconLaserClient
laser = IconLaserClient()
laser.prepare_job("test_job")
laser.set_id("SN", "123456")
laser.set_id("QR", "PRODUCT001")
laser.enable_job()
laser.start()
laser.clear_job()
Important Note
ICON Interface has undocumented behavior.
After loading a job:
laser.load_job("test_job")
the software automatically enables limits mode internally.
This causes:
all_ids -> empty response
set_id -> id_not_found
To fix this, limits must be disabled before modifying IDs:
laser.load_job("test_job")
laser.limits_off()
For convenience:
laser.prepare_job("test_job")
does both automatically.
python sdk laser industrial-automation automation hardware http-api wrapper
Basic Example
from pyiconlaser import IconLaserClient
laser = IconLaserClient()
print(laser.version())
print(laser.job_status())
print(laser.all_ids())
Supported API Methods
version()
job_status()
loaded_job()
state()
load_job()
prepare_job()
clear_job()
enable_job()
all_ids()
set_id()
start()
stop()
limits_on()
limits_off()
get_preview()
Tested Environment
- Python 3.14.4
- TYKMA ICON Interface 1.0.12.6 on Windows 11
Testing
Unit tests run without any hardware:
pytest
Integration tests communicate with a real laser running ICON Interface and
are skipped by default. Enable them with the --run-integration flag:
pytest --run-integration
Configuration
The target hardware is configured through environment variables. You can set them in two ways:
Option 1: Using a .env file (recommended)
Copy .env.example to .env and update with your hardware details:
cp .env.example .env
Then edit .env and set your values:
ICON_LASER_HOST=192.168.0.10
ICON_LASER_PORT=5287
ICON_LASER_TIMEOUT=5
ICON_LASER_JOB=test_job
ICON_LASER_ID_NAME=SN
ICON_LASER_ID_VALUE=TEST123
The .env file is automatically loaded during testing and is not committed to git.
Option 2: Setting inline with the command
ICON_LASER_HOST=192.168.0.10 ICON_LASER_JOB=test_job pytest --run-integration
Environment Variables Reference
| Variable | Description | Default |
|---|---|---|
ICON_LASER_HOST |
ICON Interface host | localhost |
ICON_LASER_PORT |
ICON Interface port | 5287 |
ICON_LASER_TIMEOUT |
Request timeout (seconds) | 5 |
ICON_LASER_JOB |
Marking job to run (required) | — |
ICON_LASER_ID_NAME |
ID field to set | SN |
ICON_LASER_ID_VALUE |
ID value to set | TEST123 |
Integration tests will physically operate the laser. Only run them on a system that is safe to mark.
License
MIT 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
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 pyiconlaser-0.2.1.tar.gz.
File metadata
- Download URL: pyiconlaser-0.2.1.tar.gz
- Upload date:
- Size: 8.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d8fc46130afd8723c02785296759392efe556e95c8b99071353f61b2b3b14934
|
|
| MD5 |
6577581cecf7151049f315889656903d
|
|
| BLAKE2b-256 |
bc65c132d34fc2723ba9acdf584d52e704a7728dc70db5909157b1dc370e272f
|
File details
Details for the file pyiconlaser-0.2.1-py3-none-any.whl.
File metadata
- Download URL: pyiconlaser-0.2.1-py3-none-any.whl
- Upload date:
- Size: 6.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
14e5d612815912fff2ee82fd807d6d7c480c7bac072f3019fa7bfd49ae1abc7d
|
|
| MD5 |
9e6b425ec0b76a6b6aaeba2e356f797c
|
|
| BLAKE2b-256 |
474a823165bc35fbca49ba76ab9f077d32900decfdccef4473179875c095be27
|