Skip to main content

A simple CAN bus monitoring tool, with dbc support.

Project description

CANpeek

CANpeek is a graphical CAN bus observer and analyzer for Linux and Windows based on Python and Qt with can databases (DBC) support and some CANopen functionality.

Features

  • 🧩 Project-based configuration with filters, DBC files, and persistent decoding options
  • 🌐 Multi-interface support: socketcan, pcan, kvaser, vector and other interfaces based on python-can
  • 📊 Dual View: Real-time Trace View and hierarchical Grouped View with signal expansion
  • 📁 Multi-DBC support with signal decoding from cantools
  • 🧠 Generic CANopen decoder with support for NMT, PDO, SDO, Heartbeat, and more
  • 🗃️ CANopen Object Dictionary with an SDO client for read/write operations
  • 📦 CAN frame transmitter, supporting both raw and signal-based (DBC) messages
  • 📜 Log support: Save/load CAN logs in all python-can IO formats
  • 🔌 Connections Management: Handling of multiple simultaneous CAN connections

Screenshots

screenshot

Installation

The interfaces avaibility depends on modules and drivers available on your system. Watch console output at startup.

With pip

Use the extra [interfaces] to install optionals python modules.

pip install canpeek[interfaces]
canpeek

From source

  1. Install uv
  2. Run uv run canpeek --extra interfaces

🤖 About the Code (aka “AI Slop” Warning)

This project includes code — and this very README — that were generated almost entirely with large language models (LLMs). Yes, the term “AI slop” was insisted upon.

While the app works and provides a full-featured CAN bus GUI, you may find:

  • Some awkward structure and bloated chunks of logic
  • Repetitive patterns that could use refactoring
  • Giant all-in-one files (yes, main.py, we’re looking at you)
  • Documentation (including this README) was AI-generated too — so if it sounds polished but slightly overconfident, that’s why.

The goal was rapid prototyping, not pristine architecture. Use it, improve it, rewrite parts of it — all contributions are welcome.

Usage

  1. Connect to a CAN interface:

    • Select backend (socketcan, pcan, kvaser, etc.)
    • Enter the channel (e.g., can0)
    • Click Connect
  2. Load DBC files via the "Project Explorer" to decode signals.

  3. Create Filters to limit visible traffic.

  4. Send CAN messages:

    • Manually from the Transmit tab
    • If the message id is in the DBC, a dedicated panel is available to edit signals values
  5. Save / Load CAN logs in multiples formats.

Other tools

CANPeek is designed to be quick & simple, you might find those intersesting:

  • cangaroo : A rather similar project in c++
  • SavvyCAN : A much more complete canbus tool

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

canpeek-0.7.0.tar.gz (3.9 MB view details)

Uploaded Source

Built Distribution

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

canpeek-0.7.0-py3-none-any.whl (3.8 MB view details)

Uploaded Python 3

File details

Details for the file canpeek-0.7.0.tar.gz.

File metadata

  • Download URL: canpeek-0.7.0.tar.gz
  • Upload date:
  • Size: 3.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.7.19

File hashes

Hashes for canpeek-0.7.0.tar.gz
Algorithm Hash digest
SHA256 e570ce865ceaec05755cf10e411ca57abcd32fcf6e0ca69ed124393ac34ee686
MD5 a9c876fe8cd8ddcfbaff974d44fc46a8
BLAKE2b-256 b25e9cdf8e08eabbad5960b29211169f7083e3228289651047501ce7c1c29b6f

See more details on using hashes here.

File details

Details for the file canpeek-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: canpeek-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 3.8 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.7.19

File hashes

Hashes for canpeek-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0dfb8cda410c79e9a9b1189ed4cbfce32ca8d5aab00805a46672388b321e8bba
MD5 2184b142afc29094da59c8d1238d50bc
BLAKE2b-256 fdadc5d01184d31f73ce37cf5e308984b0cb8f257ef61532876fe09229cb4c23

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