提到替换删除字符,可能大家使用频率比较高的是sed。
sed命令当然是非常好的使用工具,但是单讲替换功能,可能更适用于字符串。今天要说的tr,是针对字符的操作,而不是字符串。
使用方法:
tr [option] [set1] [set2] <输入流>
注意:指定的字符可以使用正则表达式;如果是文件里面的内容,请使用重定向符号
参数:
参数 | 作用 |
---|---|
-d | 删除指定的字符 |
-s | 只保留连续字符的第一个字符 |
-c | 对指定的第一个字符部分(set1)做取反操作 |
不加参数 | 将set1的字符替换为set2的字符 |
什么叫针对字符而不是字符串操作呢,举个不加参数的例子:
我们用tr命令操作,对输入的文本中的"abc"替换为"def",意思是“a”替换为"d",“b"替换为"e”,“c"替换为"f”。
针对输入中的每一个"a", “b”, "c"都会做如此操作。
对下面的文档进行测试:
test1
测试一:删除掉test1中的’laugh’字符
tr -d 'laugh' < test1
其中所有的"l",“a”,“u”,“g”, "h"字符都删掉了。
测试二:将连续重复的字符只保留一个。
tr -s [a-z][0-9] < test1
这里我们使用了正则表达式[a-z][0-9]表示所有的小写字母和阿拉伯数字,然后可以看到原来所有的连续字符都只保留一个了,如文本中的"qq",“5211314”,还有最后一行。
测试三:将除数字外的其他字符变成"*“。
这里使用-c参数:
如果不加-c参数,应该是这样,所有的数字都变成了”*":
加-c,所有除数字之外的字符都会变成"*",包括 换行符等。
测试四:
将所有小写字母改成大写字母