python-can tools
python-can comes with a range of useful command-line tools (similar to Linux can-utils). For more information see https://python-can.readthedocs.io/en/v4.5.0/scripts.html.
This page includes examples on how to use python-can tools relevant to the python-can-csscan-serial package.
Note
The examples on this page assume that the python-can-csscan-serial package has been installed and the Python environment is active.
can-logger
The can-logger tool (similar to can-utils candump) can be used to display live CAN-bus traffic or log to a file. The tool supports a range of logging file formats. For more information see https://python-can.readthedocs.io/en/v4.5.0/scripts.html#can-logger.
$ can_logger --interface csscan_serial --channel COM1
Connected to csscan_serial: CSSCAN serial on COM1
Can Logger (Started on 2024-01-01 12:00:00.000000)
Timestamp: 1707830060.859518 ID: 003 S Rx DL: 8 00 00 00 00 00 00 00 00
Timestamp: 1707830060.859518 ID: 002 S Rx DL: 8 00 00 00 00 10 00 10 00
Timestamp: 1707830060.867518 ID: 003 S Rx DL: 8 00 00 00 00 00 00 00 00
Timestamp: 1707830060.867518 ID: 002 S Rx DL: 8 00 00 00 00 10 00 10 00
Timestamp: 1707830060.880518 ID: 003 S Rx DL: 8 00 00 00 00 00 00 00 00
Timestamp: 1707830060.880518 ID: 002 S Rx DL: 8 00 00 00 00 10 00 10 00
Timestamp: 1707830060.887518 ID: 003 S Rx DL: 8 00 00 00 00 00 00 00 00
...
$ can_logger --interface csscan_serial --channel COM1 -f F:/dump.log
Connected to CSSCANSerial: CSSCAN serial on COM1
Can Logger (Started on 2024-01-01 12:00:00.000000)
can-viewer
Note
On Windows, can-viewer depends on the windows-curses library which can be installed with pip install python-can[viewer]
The can-viewer tool (similar to can-utils cansniffer) can be used to display a table of received messages. Run can_viewer -h
for at list of shortcuts. For more information see https://python-can.readthedocs.io/en/v4.5.0/scripts.html#can-viewer
$ can_viewer --interface csscan_serial --channel COM1
Count Time dt ID DLC Data
7 0.600 0.101 0x003 8 00 00 00 00 00 00 00 00
7 0.600 0.101 0x002 8 00 00 00 00 10 00 10 00
7 0.600 0.101 0x001 4 99 99 99 99
The can-viewer tool also supports simple live decoding using the -d
argument.
2:<HHHH:0.625:0.625:0.625:0.625
3:<HHHH:0.625:0.625:0.625:0.625
$ can_viewer --interface csscan_serial --channel COM1 -d rules.txt
Count Time dt ID DLC Data Parsed values
590 58.899 0.099 0x003 8 20 3E 80 1A 40 3E A0 1A 25446.4 10854.4 25497.6 10905.6
590 58.899 0.099 0x002 8 20 3E 80 1A 50 3E B0 1A 25446.4 10854.4 25523.2 10931.2
Note
See the can-viewer help for information on the signal decoding syntax.