Linux命令三:tr

上一篇 / 下一篇  2014-05-09 10:18:29 / 个人分类:Linux

用法: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"


TAG:

 

评分:0

我来说两句

Open Toolbar