Kvaser / pycanlib

The pycanlib package is a Python wrapper for Kvaser CANlib SDK.
https://pycanlib.readthedocs.io
MIT License
16 stars 4 forks source link

canlib - a Python wrapper for Kvaser CANlib

Supported Libraries and Installation

The Python canlib module wraps the Kvaser CANlib API in order to make it easy to control most aspects of any Kvaser CAN interface. For more information about Kvaser please go to https://www.kvaser.com/.

The latest version of this package is available on the Kvaser Download page <https://www.kvaser.com/downloads-kvaser/>_ (pycanlib.zip <https://www.kvaser.com/downloads-kvaser/?utm_source=software&utm_ean=7330130981911&utm_status=latest>_).

Supported platforms

Windows and Linux using Python v3.6+ (both 32 and 64 bit).

Supported libraries

The following libraries are currently supported:

============= ==================== =================== ===================== Library Module Windows Linux ============= ==================== =================== ===================== CANlib canlib.canlib canlib32.dll libcanlib.so kvaMemoLibXML canlib.kvamemolibxml kvaMemoLibXML.dll libkvamemolibxml.so kvrlib canlib.kvrlib kvrlib.dll, not supported irisdll.dll, irisflash.dll, libxml2.dll kvmlib canlib.kvmlib kvaMemoLib0600.dll, not supported, [2] kvaMemoLib0700.dll, libkvamemolib0700.so, kvaMemoLib.dll, libkvamemolib.so, kvmlib.dll libkvmlib.so kvlclib canlib.kvlclib kvlclib.dll [1] libkvlclib.so kvaDbLib canlib.kvadblib kvaDbLib.dll libkvadblib.so LINlib canlib.linlib linlib.dll liblinlib.so ============= ==================== =================== =====================

.. [1] The kvlclib.dll depends on dll files from matlab wich are installed alongside kvlclib.dll. .. [2] The kvaMemoLib0600.dll, which supports older devices, is not supported under Linux.

Installation

Install the Python package from PyPI <https://pypi.org/project/canlib/>_ using e.g. pip:

.. code-block:: shell

$ pip install canlib

If you have downloaded the package zip file from the Kvaser Download page <https://www.kvaser.com/downloads-kvaser/>_, first unzip pycanlib.zip. Then navigate to the unzipped pycanlib using the command line. It should contain the file canlib-x.y.z-py2.py3-none-any.whl, where x,y,z are version numbers. Run the following command:

.. code-block:: shell

$ pip install canlib-x.y.z-py2.py3-none-any.whl

The Kvaser CANlib DLLs or shared libraries also need to be installed:

Windows ^^^^^^^ On Windows, first install the canlib32.dll by downloading and installing "Kvaser Drivers for Windows" which can be found on the Kvaser Download page <https://www.kvaser.com/downloads-kvaser/>_ (kvaser_drivers_setup.exe <https://www.kvaser.com/downloads-kvaser/?utm_source=software&utm_ean=7330130980013&utm_status=latest>_) This will also install kvrlib.dll, irisdll.dll, irisflash.dll and libxml2.dll used by kvrlib.

The "Kvaser CANlib SDK" also needs to be downloaded from the same place (canlib.exe <https://www.kvaser.com/downloads-kvaser/?utm_source=software&utm_ean=7330130980150&utm_status=latest>_) and installed if more than just CANlib will be used. This will install the rest of the supported library dll's.

The two packages, "Kvaser Drivers for Windows" and "Kvaser CANlib SDK", contains both 32 and 64 bit versions of the included dll's.

Linux ^^^^^ On Linux, first install the libcanlib.so by downloading and installing "Kvaser LINUX Driver and SDK" which can be found on the Kvaser Download page <https://www.kvaser.com/downloads-kvaser/>_ (linuxcan.tar.gz <https://www.kvaser.com/downloads-kvaser/?utm_source=software&utm_ean=7330130980754&utm_status=latest>_).

If more than just CANlib will be used, the rest of the supported libraries will be available by downloading and installing "Linux SDK library" (kvlibsdk.tar.gz <https://www.kvaser.com/downloads-kvaser/?utm_source=software&utm_ean=7330130981966&utm_status=latest>_).

Usage

Example of using canlib to list some information about connected Kvaser devices:

.. code-block:: Python

    from canlib import canlib

    num_channels = canlib.getNumberOfChannels()
    print(f"Found {num_channels} channels")
    for ch in range(num_channels):
        chd = canlib.ChannelData(ch)
        print(f"{ch}. {chd.channel_name} ({chd.card_upc_no} / {chd.card_serial_no})")

Which may result in:

.. code-block:: shell

    Found 4 channels
    0. Kvaser Memorator Pro 2xHS v2 (channel 0) (73-30130-00819-9 / 12330)
    1. Kvaser Memorator Pro 2xHS v2 (channel 1) (73-30130-00819-9 / 12330)
    2. Kvaser Virtual CAN Driver (channel 0) (00-00000-00000-0 / 0)
    3. Kvaser Virtual CAN Driver (channel 1) (00-00000-00000-0 / 0)

.. .. code-block:: Python

       >>> from canlib import canlib
       >>> canlib.getNumberOfChannels()
       4
       >>> for ch in range(canlib.getNumberOfChannels()):
       ...     chd = canlib.ChannelData(ch)
       ...     print(f"{ch}. {chd.channel_name} ({chd.card_upc_no} / {chd.card_serial_no})")
       0. Kvaser Memorator Pro 2xHS v2 (channel 0) (73-30130-00819-9 / 12330)
       1. Kvaser Memorator Pro 2xHS v2 (channel 1) (73-30130-00819-9 / 12330)
       2. Kvaser Virtual CAN Driver (channel 0) (00-00000-00000-0 / 0)
       3. Kvaser Virtual CAN Driver (channel 1) (00-00000-00000-0 / 0)

Support

You are invited to visit the Kvaser web pages at https://www.kvaser.com/support/. If you don't find what you are looking for, you can obtain support on a time-available basis by sending an e-mail to support@kvaser.com.

Bug reports, contributions, suggestions for improvements, and similar things are much appreciated and can be sent by e-mail to support@kvaser.com.

What's new

A complete set of release notes are available in the package documentation included in the zip file available at the Kvaser Download page <https://www.kvaser.com/downloads-kvaser/>_.

Links

License

This project is licensed under the terms of the MIT license.