# **tr** ## 说明 **tr命令** 可以对来自标准输入的字符进行替换、压缩和删除。它可以将一组字符变成另一组字符,经常用来编写优美的单行命令 ## 选项 ```markdown 用法:tr [选项]... SET1 [SET2] 从标准输入中替换、缩减和/或删除字符,并将结果写到标准输出。 -c, -C, --complement 首先补足SET1,即取代所有不属于第一字符集的字符 -d, --delete 删除匹配SET1 的内容,并不作替换 -s, --squeeze-repeats 如果匹配于SET1 的字符在输入序列中存在连续的重复,在替换时会被统一缩为一个字符的长度 -t, --truncate-set1 先将SET1 的长度截为和SET2 相等 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:] 所有的十六进制数 [=字符=] 所有和指定字符相等的字符 使用方式: tr '[:lower:]' '[:upper:]' 仅在SET1 和SET2 都给出,同时没有-d 选项的时候才会进行替换。 仅在替换时才可能用到-t 选项。如果需要SET2 将被通过在末尾添加原来的末字符的方式 补充到同SET1 等长。SET2 中多余的字符将被省略。只有[:lower:] 和[:upper:] 以升序展开字符;在用于替换时的SET2 中以成对表示大小写转换。-s 作用于SET1,既不 替换也不删除,否则在替换或展开后使用SET2 缩减。 ``` ## 实例 ```bash echo "HELLO WORLD" | tr 'A-Z' 'a-z' # 将输入字符由大写转换为小写 echo 'Test' | tr '[:lower:]' '[:upper:]' # 将Test转换为大写 echo "hello 123 world 456" | tr -d '0-9' # 使用tr删除字符 cat text | tr '\t' ' ' # 将制表符转换为空格 tr -dc '[:print:]' < /dev/urandom # 过滤掉不能打印的内容 # 字符集补集,从输入文本中将不在补集中的所有字符删除;此例中补集中包含了数字0~9、空格和换行符\n,所以没有被删除,其他字 # 符全部被删除了 echo aa.,a 1 b#$bb 2 c*/cc 3 ddd 4 | tr -d -c '0-9 \n' echo "thissss is a text linnnnnnne." | tr -s ' sn' # 用tr压缩字符,可以压缩输入中重复的字符 echo 1 2 3 4 5 6 7 8 9 | xargs -n1 | echo $[ $(tr '\n' '+') 0 ] # 巧妙使用tr做数字相加操作 # 删除Windows文件“造成”的'^M'字符 cat file | tr -s "\r" "\n" > new_file cat file | tr -d "\r" > new_file ```