Skip to main content

API for BambuLab 3D Printers over MQTT

Project description

Bambulabs API

This package provides a Python API for interacting with BambuLab 3D Printers. The API enables you to control and monitor your printer programmatically, making it an essential tool for developers, makers, and automation enthusiasts. The project is open-source and available on PyPI.

Support

If you've found this package useful, help us support more printers with the link below.

"Buy Me A Coffee"

Status

flake8 pytest-unit-tests GitHub Pages

Documentation

Comprehensive documentation for this package, including API reference and usage guides, can be found here.

Installation

To install the package, use pip:

pip install bambulabs_api

Make sure you have Python 3.10 or higher installed.

Features

  • Connect and control BambuLab 3D printers programmatically.
  • Monitor printer status in real-time.
  • Execute commands and manage print jobs directly through Python code.
  • Easy setup and integration with Python environments.

Usage Example

Below is a basic example demonstrating how to connect to a BambuLab 3D printer and retrieve its status using the API:

import time
import bambulabs_api as bl

IP = '192.168.1.200'
SERIAL = 'AC12309BH109'
ACCESS_CODE = '12347890'

if __name__ == '__main__':
    print('Starting bambulabs_api example')
    print('Connecting to BambuLab 3D printer')
    print(f'IP: {IP}')
    print(f'Serial: {SERIAL}')
    print(f'Access Code: {ACCESS_CODE}')

    # Create a new instance of the API
    printer = bl.Printer(IP, ACCESS_CODE, SERIAL)

    # Connect to the BambuLab 3D printer
    printer.connect()

    time.sleep(2)

    # Get the printer status
    status = printer.get_state()
    print(f'Printer status: {status}')

    # Turn the light off
    printer.turn_light_off()

    time.sleep(2)

    # Turn the light on
    printer.turn_light_on()

    # Disconnect from the Bambulabs 3D printer
    printer.disconnect()

Known Limitations

  • X1 Printers are not fully supported yet - camera integration is not yet implemented (for api versions < 2.7.0 please see the No Camera Example).
  • H2D printers have not been tested yet.

Development

If you want to contribute to the development of this API or run it in a development environment, follow these steps:

Prerequisites

  • Conda: Make sure you have Conda installed on your system.
  • Git: Ensure Git is installed for cloning the repository.

Setup

  1. Clone the repository:

    git clone https://github.com/BambuTools/bambulabs_api.git
    
  2. Change directory:

    cd bambulabs_api
    
  3. Create the Conda environment using the provided environment.yml file:

    conda env create -f environment.yml
    

    Note: Apple M chip workaround The binary for myst_parser is not available for M1 devices yet, as a workaround

    • Delete myst_parser from environment.yml
    • run conda env create -f environment.yml
    • Execute step 4 then run pip install myst_parser
  4. Activate the environment:

    conda activate bl_api
    
  5. Install the package in development mode:

    pip install -e .
    

Running Tests

To ensure everything is working correctly, you can run the tests using pytest:

pytest

Contributing

Contributions are welcome! If you'd like to contribute to this project, please:

  1. Fork the repository.
  2. Create a new branch (git checkout -b feature-branch).
  3. Commit your changes (git commit -am 'Add new feature').
  4. Push to the branch (git push origin feature-branch).
  5. Open a pull request.

Please make sure your code follows PEP 8 guidelines and that you run tests before submitting a PR.

License

This project is licensed under the MIT License. See the LICENSE file for more details.

Support

If you encounter any issues or have questions, feel free to open an issue on the GitHub repository.

Acknowledgements

This package is an open-source project developed and maintained by the community. Special thanks to all contributors who have helped improve and enhance this API.

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

bambulabs_api-2.6.6.tar.gz (36.0 kB view details)

Uploaded Source

Built Distribution

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

bambulabs_api-2.6.6-py3-none-any.whl (26.7 kB view details)

Uploaded Python 3

File details

Details for the file bambulabs_api-2.6.6.tar.gz.

File metadata

  • Download URL: bambulabs_api-2.6.6.tar.gz
  • Upload date:
  • Size: 36.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for bambulabs_api-2.6.6.tar.gz
Algorithm Hash digest
SHA256 69aff2da11d460807ddf8ef4d9afdd5e5a625366cef7c6103f0060c3cd7cc13c
MD5 b0f70e75840c7aab517fdb5e58fd382d
BLAKE2b-256 b5cf67c41d13db19ad3cdefdb620157460250666926725607604add678d1dfac

See more details on using hashes here.

File details

Details for the file bambulabs_api-2.6.6-py3-none-any.whl.

File metadata

  • Download URL: bambulabs_api-2.6.6-py3-none-any.whl
  • Upload date:
  • Size: 26.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for bambulabs_api-2.6.6-py3-none-any.whl
Algorithm Hash digest
SHA256 f1dff54bdd328b98c00925376c886d4a8b8b57811a475e4e55ed71340572bb09
MD5 9cabb83b7dbe4598e7361941e495e5d5
BLAKE2b-256 7591a4183ae0e8e4ce4f88ed027a6e5471f9de7f63ceadc65a21a63ba7dbbc94

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