Convert between CBOR, JSON, MessagePack, TOML, and YAML
Project description
Remarshal
Convert between CBOR, JSON, MessagePack, TOML, and YAML. When installed,
provides the command line command remarshal
as well as the short commands
{cbor,json,msgpack,toml,yaml}2
{cbor,json,msgpack,toml,yaml}
. With
these commands, you can perform format conversion, reformatting, and error
detection.
Known limitations
- CBOR, MessagePack, and YAML with binary fields can not be converted to JSON or TOML. Binary fields are converted between CBOR, MessagePack, and YAML.
- TOML containing values of the Local Date-Time type can not be converted to CBOR. The Local Date type can only be converted to JSON and YAML. The Local Time type can not be converted to any other format. Offset Date-Time and its equivalents can be converted between CBOR, MessagePack, TOML, and YAML. Keys of any date-time type are converted to string TOML keys.
- Date and time types are converted to JSON strings. They can not be safely roundtripped through JSON.
- A YAML timestamp with only a date becomes a YAML timestamp or a TOML Local Date-Time for the midnight of that date. This means you can not roundtrip every YAML document through Remarshal.
Installation
You will need Python 3.8 or later. Earlier versions of Python 3 are not supported.
The recommended way to run Remarshal is to install the latest release from PyPI with pipx.
pipx install remarshal
Regular installation is not mandatory. The command
pipx run remarshal [arg ...]
will download Remarshal and run it from a temporary location. It will cache the downloaded version for up to 14 days. Remarshal will not be automatically updated during this time.
You can install Remarshal using pip.
python3 -m pip install --user remarshal
Instead of a release, you can install the development version. Prefer releases unless you have a reason to run the development version.
python3 -m pip install --user git+https://github.com/remarshal-project/remarshal
Usage
usage: remarshal.py [-h] [-v] [-i input] [--if {cbor,json,msgpack,toml,yaml}]
[--json-indent n] [-k] [-o output]
[--of {cbor,json,msgpack,toml,yaml}] [-s] [--unwrap key]
[--wrap key] [--yaml-indent n] [--yaml-style {,',",|,>}]
[--yaml-width n]
[input] [output]
Convert between CBOR, JSON, MessagePack, TOML, and YAML.
positional arguments:
input input file
output output file
options:
-h, --help show this help message and exit
-v, --version show program's version number and exit
-i input, --input input
input file
--if {cbor,json,msgpack,toml,yaml}, -if {cbor,json,msgpack,toml,yaml}, --input-format {cbor,json,msgpack,toml,yaml}
input format
--json-indent n, --indent-json n
JSON indentation
-k, --stringify Turn into strings boolean, date-time, and null keys
for JSON and TOML and null values for TOML
-o output, --output output
output file
--of {cbor,json,msgpack,toml,yaml}, -of {cbor,json,msgpack,toml,yaml}, --output-format {cbor,json,msgpack,toml,yaml}
output format
-s, --sort-keys sort JSON, TOML, YAML keys instead of preserving key
order
--unwrap key only output the data stored under the given key
--wrap key wrap the data in a map type with the given key
--yaml-indent n YAML indentation
--yaml-style {,',",|,>}
YAML formatting style
--yaml-width n YAML line width for long strings
You can use a short command
{cbor,json,msgpack,toml,yaml}2
{cbor,json,msgpack,toml,yaml}
instead of remarshal
with format arguments. The remarshal
command as well
as the short commands exit with status 0 on success, 1 on operational failure,
and 2 when they fail to parse the command line.
If no input argument input
/-i input
is given or its value is -
,
Remarshal reads input data from standard input. Similarly, with no
output
/-o output
or an output argument that is -
, it writes the result
to standard output.
Wrappers
The arguments --wrap
and --unwrap
are available to solve the problem of
converting CBOR, JSON, MessagePack, and YAML data to TOML if the top-level
element of the data is not of a dictionary type (i.e., not a map in CBOR and
MessagePack, an object in JSON, or an associative array in YAML).
You can not represent such data as TOML directly; the data must be wrapped in a
dictionary first. Passing the flag --wrap someKey
to remarshal
or one of
its short commands wraps the input data in a "wrapper" dictionary with one key,
"someKey", with the input data as its value. The flag --unwrap someKey
does
the opposite: only the value stored under the key "someKey" in the top-level
dictionary element of the input data is converted to the target format and
output; the rest of the input is ignored. If the top-level element is not a
dictionary or does not have the key "someKey", --unwrap someKey
causes an
error.
The following shell transcript demonstrates the problem and how --wrap
and
--unwrap
solve it:
$ echo '[{"a":"b"},{"c":[1,2,3]}]' | ./remarshal.py --if json --of toml
Error: cannot convert non-dictionary data to TOML; use "wrap" to wrap it in a dictionary
$ echo '[{"a":"b"},{"c":[1,2,3]}]' \
| ./remarshal.py --if json --of toml --wrap main
[[main]]
a = "b"
[[main]]
c = [1, 2, 3]
$ echo '[{"a":"b"},{"c":[1,2,3]}]' \
| ./remarshal.py --if json --wrap main - test.toml
$ ./remarshal.py test.toml --of json
{"main":[{"a":"b"},{"c":[1,2,3]}]}
$ ./remarshal.py test.toml --of json --unwrap main
[{"a":"b"},{"c":[1,2,3]}]
Examples
$ ./remarshal.py example.toml --of yaml
clients:
data:
- - gamma
- delta
- - 1
- 2
hosts:
- alpha
- omega
database:
connection_max: 5000
enabled: true
ports:
- 8001
- 8001
- 8002
server: 192.168.1.1
owner:
bio: 'GitHub Cofounder & CEO
Likes tater tots and beer.'
dob: 1979-05-27 07:32:00+00:00
name: Tom Preston-Werner
organization: GitHub
products:
- name: Hammer
sku: 738594937
- color: gray
name: Nail
sku: 284758393
servers:
alpha:
dc: eqdc10
ip: 10.0.0.1
beta:
country: 中国
dc: eqdc10
ip: 10.0.0.2
title: TOML Example
$ curl -s http://api.openweathermap.org/data/2.5/weather\?q\=Kiev,ua \
| ./remarshal.py --if json --of toml
base = "cmc stations"
cod = 200
dt = 1412532000
id = 703448
name = "Kiev"
[clouds]
all = 44
[coord]
lat = 50.42999999999999972
lon = 30.51999999999999957
[main]
humidity = 66
pressure = 1026
temp = 283.49000000000000909
temp_max = 284.14999999999997726
temp_min = 283.14999999999997726
[sys]
country = "UA"
id = 7358
message = 0.24370000000000000
sunrise = 1412481902
sunset = 1412522846
type = 1
[[weather]]
description = "scattered clouds"
icon = "03n"
id = 802
main = "Clouds"
[wind]
deg = 80
speed = 2
License
MIT. See the file LICENSE
.
example.toml
from https://github.com/toml-lang/toml. example.json
,
example.msgpack
, example.cbor
, example.yml
, tests/bin.msgpack
, and
tests/bin.yml
are derived from it.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file remarshal-0.17.0.tar.gz
.
File metadata
- Download URL: remarshal-0.17.0.tar.gz
- Upload date:
- Size: 12.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.5.1 PyPy/7.3.12 Linux/5.19.0-50-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c52689848453d4763c45eafff5ee9dc07ae8ac0b1814438a48abd21cbbc9e869 |
|
MD5 | 8ce08f86d2d8c3ca834b5384fa5c4bd1 |
|
BLAKE2b-256 | 90f5f1ba99f0d6178fca1070acc0dd107efed7dddc74d999c773cc514fc4add9 |
File details
Details for the file remarshal-0.17.0-py3-none-any.whl
.
File metadata
- Download URL: remarshal-0.17.0-py3-none-any.whl
- Upload date:
- Size: 10.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.5.1 PyPy/7.3.12 Linux/5.19.0-50-generic
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 602472e4306a3981492145f9acee9d7df06bcea0a405ac1a358a12f646249eaa |
|
MD5 | e616c7515538dfb7630f76bb2c757383 |
|
BLAKE2b-256 | ff77174110266003d74b91a5d360a2dfce023c349ef6a24f614b299125dd276c |