tr


Translate, squeeze, and/or delete characters from standard input, writing to standard output.

Usage

tr [OPTION]... SET1 [SET2]

Flags

  -c, -C, --complement    use the complement of SET1
  -d, --delete            delete characters in SET1, do not translate
  -s, --squeeze-repeats   replace each sequence of a repeated character
                            that is listed in the last specified SET,
                            with a single occurrence of that character
  -t, --truncate-set1     first truncate SET1 to length of SET2
      --help     display this help and exit
      --version  output version information and exit

SETs are specified as strings of characters.  Most represent themselves.
Interpreted sequences are:

  \NNN            character with octal value NNN (1 to 3 octal digits)
  \\              backslash
  \a              audible BEL
  \b              backspace
  \f              form feed
  \n              new line
  \r              return
  \t              horizontal tab
  \v              vertical tab
  CHAR1-CHAR2     all characters from CHAR1 to CHAR2 in ascending order
  [CHAR*]         in SET2, copies of CHAR until length of SET1
  [CHAR*REPEAT]   REPEAT copies of CHAR, REPEAT octal if starting with 0
  [:alnum:]       all letters and digits
  [:alpha:]       all letters
  [:blank:]       all horizontal whitespace
  [:cntrl:]       all control characters
  [:digit:]       all digits
  [:graph:]       all printable characters, not including space
  [:lower:]       all lower case letters
  [:print:]       all printable characters, including space
  [:punct:]       all punctuation characters
  [:space:]       all horizontal or vertical whitespace
  [:upper:]       all upper case letters
  [:xdigit:]      all hexadecimal digits
  [=CHAR=]        all characters which are equivalent to CHAR

Translation occurs if -d is not given and both SET1 and SET2 appear.
-t may be used only when translating.  SET2 is extended to length of
SET1 by repeating its last character as necessary.  Excess characters
of SET2 are ignored.  Only [:lower:] and [:upper:] are guaranteed to
expand in ascending order; used in SET2 while translating, they may
only be used in pairs to specify case conversion.  -s uses the last
specified SET, and occurs after translation or deletion.

GNU coreutils online help: <https://www.gnu.org/software/coreutils/>
Full documentation at: <https://www.gnu.org/software/coreutils/tr>
or available locally via: info '(coreutils) tr invocation'

Examples

Remove every char you don’t want in output

cat example.json
{ "subdomains": [ "docs", "blogs", "apex", "cloud", "oss", "community", "asktom", "education", "forums", "linux", "edelivery", "labs" ], "meta": { "limit_reached": true }, "endpoint": "/v1/domain/example.com" }
$ jq -r '.subdomains' example.json | tr -d '",[] '

docs
blogs
apex
cloud
oss
community
asktom
education
forums
linux
edelivery
labs

All lines in file to upper/lower case

$ cat da.txt | tr '[:upper:]' '[:lower:]'       
svc_connect
svc_crm365
svc_lmt
svc_curium

Delete newlines from current output/file

$ diff file1 file2
369a370
> c
698d698
< r
1075a1076
> y
1400d1400
< p
1722a1723
> t
2127d2127
< 0
2483a2484
> r
2829d2829
< r
3224a3225
> o
3586d3586
< f
3988a3989
> f
4332d4332
< s
4731a4732
> e
5096d5096
< c
$ diff file1 file2 | grep -v "^[0-9c0-9]" | cut -d ' ' -f2 | tr --delete '\n'
crypt0rroffsec

URL List