2025-03-14 21:59:59 -06:00
# q
> Execute SQL-like queries on CSV and TSV files.
> More information: <https://harelba.github.io/q>.
- Query a CSV file by specifying the delimiter as ',':
2025-05-08 12:26:01 -06:00
`q {{[-d|--delimiter]}} ',' "SELECT * from {{path/to/file}}"`
2025-03-14 21:59:59 -06:00
- Query a TSV file:
2025-05-08 12:26:01 -06:00
`q {{[-t|--tab-delimited]}} "SELECT * from {{path/to/file}}"`
2025-03-14 21:59:59 -06:00
- Query file with header row:
2025-05-08 12:26:01 -06:00
`q {{[-d|--delimiter]}} {{delimiter}} {{[-H|--skip-header]}} "SELECT * from {{path/to/file}}"`
2025-03-14 21:59:59 -06:00
- Read data from `stdin` ; '-' in the query represents the data from `stdin` :
`{{output}} | q "select * from -"`
- Join two files (aliased as `f1` and `f2` in the example) on column `c1` , a common column:
`q "SELECT * FROM {{path/to/file}} f1 JOIN {{path/to/other_file}} f2 ON (f1.c1 = f2.c1)"`
2025-05-08 12:26:01 -06:00
- Format output using an output delimiter with an output header line (Note: Command will output column names based on the input file header or the column aliases overridden in the query):
2025-03-14 21:59:59 -06:00
2025-05-08 12:26:01 -06:00
`q {{[-D|--output-delimiter]}} {{delimiter}} {{[-O|--output-header]}} "SELECT {{column}} as {{alias}} from {{path/to/file}}"`