Parsm is the powerful command-line tool that understands structured text better than sed, awk, grep or grok.
parsm automatically detects and parses multiple data formats (JSON, CSV, YAML, TOML, logfmt, and plain text) and provides powerful filtering and templating capabilities through an intuitive syntax.
By default, parsm outputs the original input when a filter matches. For custom output formatting, use templates.
cargo install parsmcargo install --path .Or build from source:
git clone <repository-url>
cd parsm
cargo build --release
./target/release/parsm --examples# Basic usage
parsm [FILTER] [TEMPLATE]
# Examples
parsm --examples
# Extract a field
echo '{"name": "Alice"}' | parsm 'name'
# Nested fields
echo '{"user": {"email": "[email protected]"}}' | parsm 'user.email'
# Filtering
echo '{"age": 30}' | parsm 'age > 25'
# Filter and format
echo '{"name": "Alice", "age": 30}' | parsm 'age > 25 [${name} is ${age}]'- JSON
- CSV
- YAML
- TOML
- Logfmt
- Plain Text
- Comparison: ==,!=,<,<=,>,>=
- String ops: *=(contains),^=(starts with),$=(ends with),~=(regex match)
- Boolean logic: &&,||,!
- Truthy check: field?
Examples:
name == "Alice" && age > 25
email ~ "@example.com"
user.active?- Variables: [${name}]or$name
- Literal: [name]
Example:
parsm 'age > 25 [${name} is ${age}]'- Simple: name
- Nested: user.email
- Quoted (special chars): 'special-field'
- CSV/Text: field_0,word_0
cat Cargo.toml | parsm 'package.name'
echo '{"user": {"email": "[email protected]"}}' | parsm 'user.email'echo 'Alice,30,Engineer' | parsm 'field_1 > "25" [${1} (${2})]'echo 'level=error msg="DB error"' | parsm 'level == "error" [${msg}]'parsm [OPTIONS] [FILTER] [TEMPLATE]
Arguments:
  [FILTER]    Filter expression (optional)
  [TEMPLATE]  Template expression for output formatting (optional)
Options:
      --examples  Show usage examples
      --json      Force JSON format detection
      --yaml      Force YAML format detection
      --csv       Force CSV format detection
      --toml      Force TOML format detection
      --logfmt    Force logfmt format detection
      --text      Force plain text format detection
  -h, --help      Print help
  -V, --version   Print version| Flag | Format | 
|---|---|
| --json | JSON | 
| --yaml | YAML | 
| --csv | CSV | 
| --toml | TOML | 
| --logfmt | logfmt | 
| --text | Plain Text | 
| Feature | parsm | jq | awk | sed | 
|---|---|---|---|---|
| Multi-format | ✅ JSON, CSV, YAML, TOML, logfmt, text | JSON only | Text | Text | 
| Auto-detection | ✅ Automatic | ❌ Manual | ❌ Manual | ❌ Manual | 
| Field extraction | ✅ Simple namesyntax | ✅ .namesyntax | Limited | ❌ No | 
| Simple syntax | ✅ Low | Medium | Complex | Medium | 
- Build: cargo build
- Test: cargo test
- Lint: cargo fmt && cargo clippy
- Fork repository
- Create feature branch
- Write tests and code
- Run tests and lint checks
- Submit a pull request
See LICENSE.
See CHANGELOG.md.
# Basic filtering - outputs original input when filter matches
echo '{"name": "Alice", "age": 30}' | parsm 'age > 25'
# Output: {"name": "Alice", "age": 30}
# Filtering with custom template
echo '{"name": "Alice", "age": 30}' | parsm 'age > 25 [${name} is ${age}]'
# Output: Alice is 30
# Access original input in templates with ${0}
echo '{"name": "Alice", "age": 30}' | parsm '[Original: ${0}, Name: ${name}]'
# Output: Original: {"name": "Alice", "age": 30}, Name: Alice