https://github.com/noborus/guesswidth
Guess the width (fwf) output without delimiters in commands that output to the terminal.
https://github.com/noborus/guesswidth
fixed-width fwf
Last synced: 7 months ago
JSON representation
Guess the width (fwf) output without delimiters in commands that output to the terminal.
- Host: GitHub
- URL: https://github.com/noborus/guesswidth
- Owner: noborus
- License: mit
- Created: 2023-03-13T00:51:51.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-09-16T05:20:46.000Z (about 1 year ago)
- Last Synced: 2025-03-04T22:56:48.071Z (7 months ago)
- Topics: fixed-width, fwf
- Language: Go
- Homepage:
- Size: 168 KB
- Stars: 30
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# guesswidth
[](https://pkg.go.dev/github.com/noborus/guesswidth) [](https://github.com/noborus/guesswidth/actions/workflows/build.yml)
## Overview
guesswidth guesses the column position for fixed-width formats(fwf).
The output of the `ps` command has no delimiters, making the values difficult to machine-readable.
guesswidth guesses smarter than just space delimiters.guesswidth is guessed based on the position of characters in the **header**.
So having a header will give you better results.## Install command
There is also a guesswidth command.
```console
go install github.com/noborus/guesswidth/cmd/guesswidth@latest
```Guess the width output with no delimiters in the command.
```console
$ ps
PID TTY TIME CMD
302965 pts/3 00:00:12 zsh
733211 pts/3 00:00:00 ps
733212 pts/3 00:00:00 tee
733213 pts/3 00:00:00 guesswidth
```Split the output like this:
```console
$ ps | guesswidth
PID| TTY | TIME|CMD
302965| pts/3 | 00:00:08|zsh
539529| pts/3 | 00:00:00|ps
539530| pts/3 | 00:00:00|guesswidth
```It can be converted to `csv`.
```console
$ ps | guesswidth csv
PID,TTY,TIME,CMD
302965,pts/3,00:00:12,zsh
733211,pts/3,00:00:00,ps
733212,pts/3,00:00:00,tee
733213,pts/3,00:00:00,guesswidth
``````console
ps | guesswidth --align
PID|TTY | TIME|CMD
302965|pts/3|00:00:12|zsh
733211|pts/3|00:00:00|ps
733212|pts/3|00:00:00|tee
733213|pts/3|00:00:00|guesswidth
```## Usage
```console
$ guesswidth -h [~/dev/src/github.com/noborus/guesswidth]
Guess the width of the columns from the header and body,
split them, insert fences and output.Usage:
guesswidth [flags]
guesswidth [command]Available Commands:
completion Generate the autocompletion script for the specified shell
csv Output in csv format
help Help about any commandFlags:
-a, --align align the output
--fence string fence (default "|")
--header int header line number (default 1)
-h, --help help for guesswidth
--scannum int number of line to scan (default 100)
--split int maximum number of splits (default -1)
-v, --version version for guesswidthUse "guesswidth [command] --help" for more information about a command.
```## Examples
guesswidth inserts a delimiter (| by default)
(Colors are changed here for clarity).Even if there are spaces in the header or body, they will be separated correctly.
### ps

### docker ps

### docker node
