Skip to main content

Convert tabular data (CSV, Parquet, Excel, etc.) to MCAP format with support for ROS2 and JSON schemas

Project description

Tabular2MCAP

Documentation Supported by Alloy

Convert tabular data (CSV, Parquet, Excel, and more) to MCAP format with support for ROS2 and JSON schemas, enabling seamless integration with robotics workflows, data visualization in Foxglove Studio, and playback of sensor and navigation data.

Please ⭐ if this helps you today!

Features

  • Multi-Format Support: Convert to ROS2 or JSON messages with support for standard message types (e.g., sensor_msgs/msg/NavSatFix, geometry_msgs/msg/TransformStamped, foxglove.LocationFix, and more)
  • Configuration-Driven: YAML-based mapping with Jinja2 templates for flexible data transformation
  • Batch Processing: Process multiple files and directories with a single command

Quick Start

Installation

# Basic installation (CSV, TSV, JSON, Pickle)
pip install tabular2mcap

# With optional formats
pip install tabular2mcap[parquet]      # Parquet files
pip install tabular2mcap[feather]      # Feather files
pip install tabular2mcap[orc]          # ORC files
pip install tabular2mcap[excel]        # Excel files (.xlsx)
pip install tabular2mcap[excel-legacy] # Excel files (.xls)
pip install tabular2mcap[xml]          # XML files
pip install tabular2mcap[all-formats]  # All formats

Basic Usage

tabular2mcap \
  -i /path/to/data/directory \
  -o output.mcap \
  -c config.yaml \
  -f converter_functions.yaml

Configuration System

The tool uses YAML configuration files to define how CSV files should be processed. These are:

  • config.yaml: Defines file patterns and converter function mappings
  • converter_functions.yaml: Contains Jinja2 templates for data transformation

Example Configurations

JSON Format:

# config.yaml
writer_format: "json"
file_mappings:
  - file_pattern: 'data.csv'
    converter_functions:
      - function_name: "row_to_foxglove_location_fix"
        schema_name: "foxglove.LocationFix"
        topic_suffix: "LocationFix"

ROS2 Format:

# config.yaml
writer_format: "ros2"
tabular_mappings:
  - file_pattern: '**/data.csv'
    converter_functions:
      - function_name: "row_to_nav_sat_fix"
        schema_name: "sensor_msgs/msg/NavSatFix"
        topic_suffix: "NavSatFix"

Tutorial

For detailed instructions on adding support for new types of CSV data, see the Tutorial in the documentation.

Supported By

Alloy

This project is supported by Alloy - Search all your robot data in plain english. Alloy provides a platform to unify image, time-series, and log search for robotics teams.

License

GNU General Public License v3.0 - see LICENSE for details.

Contributing

See CONTRIBUTING.md for development setup, testing, and contribution guidelines.

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

tabular2mcap-0.1.8.tar.gz (84.4 kB view details)

Uploaded Source

Built Distribution

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

tabular2mcap-0.1.8-py3-none-any.whl (111.8 kB view details)

Uploaded Python 3

File details

Details for the file tabular2mcap-0.1.8.tar.gz.

File metadata

  • Download URL: tabular2mcap-0.1.8.tar.gz
  • Upload date:
  • Size: 84.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for tabular2mcap-0.1.8.tar.gz
Algorithm Hash digest
SHA256 09572955c871de20b5ed4a6693c4fe0bf2e7e98b7f3bec998e657eebddb632a8
MD5 e6746010cfc0bfcabe21f3159c8754f0
BLAKE2b-256 2b51becbe180de666879143c61b7a2ab30d68de323204d59c3c6701a4c2402ad

See more details on using hashes here.

Provenance

The following attestation bundles were made for tabular2mcap-0.1.8.tar.gz:

Publisher: publish.yml on alloyrobotics/tabular2mcap

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tabular2mcap-0.1.8-py3-none-any.whl.

File metadata

  • Download URL: tabular2mcap-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 111.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for tabular2mcap-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 c82536fb9cd4091acd521960dcf6c460ae720cbc5a88ab7ef9032608230403dd
MD5 bc8f22826675ac7b2dae46ecc5e97d61
BLAKE2b-256 72678a2d75e062d31b9895497b1965a7f84bf6071fa9f1d88fae7fc504a05e74

See more details on using hashes here.

Provenance

The following attestation bundles were made for tabular2mcap-0.1.8-py3-none-any.whl:

Publisher: publish.yml on alloyrobotics/tabular2mcap

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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