Linux系统中tr命令的基本使用教程
用法: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 缩减。
tr命令中的参数 -c 比较实用,可以用字符串1中字符集的补集替换此字符集,要求字符集为a s c i i。然后在终端上试了一条命令:
tr -cs "[a-z][a-z]" "[\012*]" <diary.txt
这是将文件 diary.txt 内的非字符数据转换成换行符,然后用 -s 选项删除所有重复出现字符序列,只保留第一个;即将重复出现字符串压缩为一个字符串。
后来仔细看这条命令时,发现在 \012 后面加了个 * ,当我去掉这个 * 时,再运行,发现得出的结果全在同一行,并且用 ] (左中括号)隔开,然后我又试着 用 \n 代替 \012,
发现也是只有在 \n 后加 * 才得出正确的结果。后来将中括号去掉。这是不要 * 时可以输出正确结果,发而加了 * 后会将结果都输出在一行,中间用 * 隔开。
猜想:是否在加中括号后,里面的特殊字符后都要加 *,无论是用字母表示的,还是用八进制数表示的。
下面再举一些例子:
[root@localhost zhangy]# echo "tank" |tr a-z a-z #大写字母转小写
tank
[root@localhost zhangy]# echo 'tank zhang' | tr a-z a-z #小写字线转大写
tank zhang
[root@localhost zhangy]# cat aaa.txt #原文件
aaa
bbb
[root@localhost zhangy]# cat aaa.txt|tr 'a' 'c' #字母c替换字母a
ccc
bbb
[root@localhost zhangy]# cat aaa.txt|tr -d 'a' #删除所有字母a
bbb
[root@localhost zhangy]# cat aaa.txt|tr -d '\n\t' 删除文件file中出现的换行'\n'、制表'\t'字符
aaabbb
[root@localhost zhangy]# cat aaa.txt|tr -s [a-za-z] #删除重复的字母
a
b
[root@localhost zhangy]# cat aaa.txt|tr -s '\n' #删除空行
aaa
bbb
[root@localhost zhangy]# cat aaa.txt |tr -s '\011' '\040' #用空格符\040替换制表符\011
aaa
bbb
# tr a c < test #将test文件中的a变成c