skip to navigation
skip to content

Not Logged In

pluckr 0.0.9

Pluck columns from CSV files in the command line. Like cut or awk, but doesn't choke on delimiter escaping.

Pluck columns from csv files in the commandline. Like cut or awk, but without choking on delimiter escaping.

install

pip install pluckr. Done.

usage

Grab columns 2 and 3 from stdin (-f is one-indexed):

pluckr -f 2,3 < sample1.csv

Or straight from a file:

pluckr -f 2,1 sample1.csv

Your requested order is retained:

pluckr -f 1,2 sample1.csv != pluckr -f 2,1 sample1.csv

You can use Python’s negative indices… grab the first and last cols:

pluckr -f 1,-1 sample1.csv

And you can mix in ranges for column selection:

pluckr -f 2,4-6,9 sample1.csv

Can’t be sure which columns exist or what their indices are?

pluckr –names sample1.csv

Fields that don’t exist (e.g. -f11111) will be ignored.

Preprended line numbers can be helpful:

cat sample1.csv | pluckr –line-numbers

Skip header row(s):

cat sample1.csv | pluckr -s1

Grab all but the 2nd column (drop columns instead of selecting them):

pluckr -f 1 -i < sample2.csv

Read (and write) various delimiters:

pluckr -d, –out-delimiter=| < with-commas.csv > with-pipes.csv

Note that passing tabs as arguments can be awkward; in a pinch, use:

pluckr -d $’t’

help

Via –help:

usage: pluckr [-h] [-f FIELDS] [-i] [-d DELIMITER] [-q QUOTECHAR] [-s SKIP]
[-l] [-n] [infile]

Grab columns from csv input. http://github.com/philadams/pluckr

positional arguments:
infile input file (.csv)
optional arguments:
<kbd>-h, --help</kbd> show this help message and exit
<kbd>-f <var>FIELDS</var></kbd> ordered list of columns to retain; one-indexed
<kbd>-i, --inverse</kbd> invert column retention: drop those in -f
<kbd>-d <var>DELIMITER</var>, --delimiter <var>DELIMITER</var></kbd>
 field delimiter when reading infile
<kbd>-q <var>QUOTECHAR</var>, --quotechar <var>QUOTECHAR</var></kbd>
 field quotechar when reading infile
<kbd>-s <var>SKIP</var>, --skip <var>SKIP</var></kbd>
 number of rows to skip
<kbd>-l, --line-numbers</kbd>
 prepend line numbers to output
<kbd>-n, --names</kbd> print column names; assumes one header row

tests

This project uses [roundup](https://github.com/bmizerany/roundup) for testing. Run tests with make test.

future

  • allow -f to take columns by name when there’s a header row?
  • implement –out-x for output delimiters etc.
  • json output? or, contribute a cli to kennethreitz/tablib
  • add out delimiter support
  • add out quotechar support
 
File Type Py Version Uploaded on Size
pluckr-0.0.9.tar.gz (md5) Source 2015-02-27 3KB
  • Downloads (All Versions):
  • 37 downloads in the last day
  • 155 downloads in the last week
  • 597 downloads in the last month