用法:tr [选项]... SET1 [SET2]
从标准输入中替换、缩减和/或删除字符,并将结果写到标准输出。
-c, -C, --complement 首先补足SET1
-d, --delete 删除匹配SET1 的内容,并不作替换
-s, --squeeze-repeats 如果匹配于SET1 的字符在输入序列中存在连续的
重复,在替换时会被统一缩为一个字符的长度
-t, --truncate-set1 先将SET1 的长度截为和SET2 相等
--help 显示此帮助信息并退出
--version 显示版本信息并退出
SET 是一组字符串,一般都可按照字面含义理解。解析序列如下:
\NNN 八进制值为NNN 的字符(1 至3 个数位)
\\ 反斜杠
\a 终端鸣响
\b 退格
\f 换页
\n 换行
\r 回车
\t 水平制表符
\v 垂直制表符
字符1-字符2 从字符1
到字符2 的升序递增过程中经历的所有字符
[字符*] 在SET2 中适用,指定字符会被连续复制直到吻合设置1 的长度
[字符*次数] 对字符执行指定次数的复制,若次数以 0 开头则被视为八进制数
[:alnum:] 所有的字母和数字
[:alpha:] 所有的字母
[:blank:] 所有呈水平排列的空白字符
[:cntrl:] 所有的控制字符
[:digit:] 所有的数字
[:graph:] 所有的可打印字符,不包括空格
[:lower:] 所有的小写字母
[:print:] 所有的可打印字符,包括空格
[:punct:] 所有的标点字符
[:space:] 所有呈水平或垂直排列的空白字符
[:upper:] 所有的大写字母
[:xdigit:] 所有的十六进制数
[=字符=] 所有和指定字符相等的字符
仅在SET1 和SET2 都给出,同时没有-d 选项的时候才会进行替换。
仅在替换时才可能用到-t 选项。如果需要SET2
将被通过在末尾添加原来的末字符的方式
补充到同SET1 等长。SET2 中多余的字符将被省略。只有[:lower:]
和[:upper:]
以升序展开字符;在用于替换时的SET2 中以成对表示大小写转换。-s
作用于SET1,既不
替换也不删除,否则在替换或展开后使用SET2 缩减。
例子:
1、将文件file中出现的"abc"替换为"xyz"
# tr "abc" "xyz" < file >new_file
【注意】凡是在file中出现的"a"字母,都替换成"x"字母,"b"字母替换为"y"字母,"c"字母替换为"z"字母。而不是将字符串"abc"替换为字符串"xyz"。
2、使用tr命令“统一”字母大小写 ,小写 --> 大写
# tr [a-z] [A-Z] < file >new_file
3、删除文件file中出现的"Snail"字符
# tr -d "Snail" < file >new_file
【注意】凡是在file文件中出现的'S','n','a','i','l'字符都会被删除,而不是紧紧删除出现的"Snail”字符串。
4、删除Windows文件“造成”的'^M'字符
# tr -d "\r" < file >new_file
5、删除文件file中出现的换行'\n'、制表'\t'字符
# tr -d "\n\t" < file >new_file
不可见字符都得用转义字符来表示的,这个都是统一的。
6、删除“连续着的”重复字母,只保留第一个
# tr -s [a-zA-Z] < file >new_file
7、删除空行
# tr -s "\n" < file >new_file
8、用空格符\040替换制表符\011
# tr -s "\011" "\040" < file >new_file
9、把路径变量中的冒号":"替换成换行符"\n" ,这样看到的路径变量更清晰
# echo $PATH | tr -s ":" "\n"