Python CLI tool and library for diffing CSV files
Project description
csv-diff
Tool for viewing the difference between two CSV files.
Consider two CSV files:
one.csv
id,name,age
1,Cleo,4
2,Pancakes,2
two.csv
id,name,age
1,Cleo,5
3,Bailey,1
csv-diff can show a human-readable summary of differences between the files:
$ csv-diff one.csv two.csv --key=id
1 row added, 1 row removed, 1 row changed
1 row added
{"id": "3", "name": "Bailey", "age": "1"}
1 row removed
{"id": "2", "name": "Pancakes", "age": "2"}
1 row changed
Row 1
age: "4" => "5"
The --key=id option means that the id column should be treated as the unique key, to identify which records have changed.
You can also run it using the --json option to get a machine-readable difference:
$ csv-diff one.csv two.csv --key=id --json
{
"added": [
{
"id": "3",
"name": "Bailey",
"age": "1"
}
],
"removed": [
{
"id": "2",
"name": "Pancakes",
"age": "2"
}
],
"changed": [
{
"key": "1",
"changes": {
"age": [
"4",
"5"
]
}
}
]
}
You can also import the Python library into your own code like so:
from csv_diff import load_csv, compare
diff = compare(
load_csv(open("one.csv"), key="id"),
load_csv(open("two.csv"), key="id")
)
diff will now contain the same data structure as the output in the --json example above.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file csv_diff-0.2-py3-none-any.whl.
File metadata
- Download URL: csv_diff-0.2-py3-none-any.whl
- Upload date:
- Size: 9.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.6.2 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
03d7ea821a0f32413cb731c579aea6e109cb3ac0abf529adf15a3a0a7751bf34
|
|
| MD5 |
bc3d456869269bbd25e2179cdfb1399f
|
|
| BLAKE2b-256 |
1d1baf8fcfe538329d6d3b52a8677cc140485145d14438d8d31955fbff42df0c
|

