tr删除替换详解
tr(translate缩写)主要用于删除文件中的控制字符,或进行字符转换。
语法:tr [–c/d/s/t] [SET1] [SET2] #SET1: 字符集1; SET2:字符集2
-c: complement 用SET2替换除SET1以外的字符。
-d: delete 删除SET1中所有的字符,不转换。
-s: squeeze-repeats 压缩SET1中重复的字符。
-t: truncate-set1 将SET1用SET2转换,一般缺省为-t。
1、去除重复的字符
# 删除空白行就是删除换行符/n。
# 注意:这些空白行上只有回车符,没有空格符。
shenweiyan@localhost :: ~ => cat test.txt I love linux! Hello World! Shell is worthy to been studied.
# 这里用换行符的转义字符\n.
#注意:此处用-s删除了多余的换行符,如果用-d,则会删除所有的换行符.
shenwy@shen-T440s :: /projects/shell => cat test.txt | tr -s ["\n"] I love linux! Hello World! Shell is worthy to been studied. shenwy@shen-T440s :: /projects/shell => cat test.txt | tr -d ["\n"] I love linux! Hello World! Shell is worthy to been studied.
# 也可以用八进制符\012,\012与\n都是换行符。
shenwy@shen-T440s :: /projects/shell => cat test.txt | tr -s "[\012]" I love linux! Hello World! Shell is worthy to been studied. shenwy@shen-T440s :: /projects/shell => cat test.txt | tr -d "[\012]" I love linux! Hello World! Shell is worthy to been studied.
2、大小写互换
# 将语句中所有的小写字母变成大写字母,其中-t可省略。
shenwy@shen-T440s :: /projects/shell => echo "Hello World I Love You" |tr [a-z] [A-Z] HELLO WORLD I LOVE YOU
# 将语句中所有的大写字母变成小写字母。
shenwy@shen-T440s :: /projects/shell => echo "Hello World I Love You. " | tr [A-Z] [a-z] hello world i love you.
# 也可以利用字符类进行转换: [:lower:]代表小写字母,[:upper:]代表大写字母。
shenwy@shen-T440s :: /projects/shell => echo "Hello World I Love You. " |tr [:lower:] [:upper:] HELLO WORLD I LOVE YOU.
3、删除指定的字符
# 处理的示例文本如下:
# 现在要删除处理星期之外的所有字符:-d代表删除; [0-9]代表所有的数字; [: ]代表冒号和空格。
4、利用-c进行补集的替换
# 有时候在文本中我们只知道要保留的一些字符,其他字符种类繁多,就可以使用补集的替换。
# 我们只需要星期,则思路就是除了字母,其他统统替换掉。
# 这里,-c:用换行符替换掉除了字母外的所有字符;-s:删除多余的换行符。
$ cat test.txt|tr -cs "[a-z][A-Z]" "\n"
总结:其中大小写字母的转换,删除不需要的字符比较常用。tr语法简单,易用。
———— 2013.12.23.Shenweiyan
tr删除替换详解的更多相关文章
- 【转帖】linux sort,uniq,cut,wc,tr,xargs命令详解
linux sort,uniq,cut,wc,tr,xargs命令详解 http://embeddedlinux.org.cn/emb-linux/entry-level/201607/21-5550 ...
- B树和B+树的插入、删除图文详解(good)
B树和B+树的插入.删除图文详解 1. B树 1. B树的定义 B树也称B-树,它是一颗多路平衡查找树.我们描述一颗B树时需要指定它的阶数,阶数表示了一个结点最多有多少个孩子结点,一般用字母m表示阶数 ...
- c++排序二叉树的出现的私有函数讨论,以及二叉树的删除操作详解
c++排序二叉树的出现的私有函数讨论, 以及二叉树的删除操作详解 标签(空格分隔): c++ 前言 我在c++学习的过程中, 最近打了一个排序二叉树的题目,题目中出现了私有函数成员,当时没有理解清楚这 ...
- Farseer.net轻量级开源框架 入门篇:删除数据详解
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 修改数据详解 下一篇:Farseer.net轻量级开源框架 入门篇: 查询数据详解 ...
- Linux下的tr编辑器命令详解
通过使用 tr,您可以非常容易地实现 sed 的许多最基本功能.您可以将 tr 看作为 sed 的(极其)简化的变体:它可以用一个字符来替换另一个字符,或者可以完全除去一些字符.您也可以用它来除去重复 ...
- B树和B+树的插入、删除图文详解
简介:本文主要介绍了B树和B+树的插入.删除操作.写这篇博客的目的是发现没有相关博客以举例的方式详细介绍B+树的相关操作,由于自身对某些细节也感到很迷惑,通过查阅相关资料,对B+树的操作有所顿悟,写下 ...
- 转:B树和B+树的插入、删除图文详解
如需转载,请注明出处 http://www.cnblogs.com/nullzx/ 1. B树 1. B树的定义 B树也称B-树,它是一颗多路平衡查找树.我们描述一颗B树时需要指定它的阶数,阶数表示了 ...
- C/C++宏替换详解
目录 1. 基本形式 2. 宏展开中的陷阱 3. #undef 4. 宏参数.# 和 ## 1. 基本形式 #define name replacement_text 通常情况下,#define 指令 ...
- MemCache的LRU删除机制详解
本节主要讲解一下MC的LRU的删除机制和一些参数的限制 MC的过期数据惰性删除 1.当某个值过期后,并没有从内存中删除,因此,我们在进行st ats统计信息的时候,curr_items有其信息(它的数 ...
随机推荐
- sqlserver 2008 局域网跨服务器T-SQL操作(一)
--查看当前链接情况: select * from sys.servers; --增加链接,参数:服务器别名,为链接服务器的OLE DB数据源的产品名称,与此数据源对应的OLE DB访问接口的唯一编程 ...
- sqlserver 2008存储过程 多个可空条件任意组合
很多程序员在实际开发中,经常遇到这种情况,列表上方有很多条件,包含下拉框,输入框等等,这些条件都可以不输入,如果我们需要写一个存储过程,很多条件挨个判断是否为空,且进行任意组合,任何一个开发人员都会疯 ...
- zoj1093 Monkey and Banana
写到现在,发现1025,1076之前写的都是同一种题型:关于DAG的最长路(最短路). 首先要建立模型,根据关系,确定点和点之间的关系,构成一个DAG,前面几道题每个点之间距离默认为1,这一道题不同点 ...
- LED大屏发布系统
开发LED大屏发布系统已经有5.6年里了,可以根据专家.用户的要求进行布置,所有的数据都是通过TCP通讯获得的,所有的显示项目都是通过配置文件进行设置的,所以系统运行效率高.灵活.界面丰富多彩等.
- Almost Prime
Description Almost Prime time limit per test: 2 seconds memory limit per test: 256 megabytes input: ...
- sqlserver 增加用户并分配权限
1.创建用户cmd2:CREATE LOGIN cmd2 WITH PASSWORD='123qwe!@#',DEFAULT_DATABASE=DEV_CMD CREATE USER cmd2 FO ...
- 设置高级的Logstash 管道
设置高级的Logstash 管道: 一个Logstash 管道在很多实用例子有一个或者多个输入,filter,和output 插件. 本节中 创建Logstash 配置文件来指定那些插件和讨论每个插件 ...
- 适合入门自学服装裁剪滴书(更新ing)
[♣]适合入门自学服装裁剪滴书(更新ing) [♣]适合入门自学服装裁剪滴书(更新ing) 适合入门自学服装裁剪滴书(更新ing) 来自: 裁缝阿普(不为良匠,便为良医.) 2014-04-06 23 ...
- document.body.scrollTop与document.documentElement.scrollTop兼容
这两天在写一个JS的网页右键菜单,在实现菜单定位的时候发现了这个问题:chrome居然不认识document.documentElement.scrollTop! 看前辈们的文章,纷纷表示如果有文档声 ...
- LightOJ 1085(树状数组+离散化+DP,线段树)
All Possible Increasing Subsequences Time Limit:3000MS Memory Limit:65536KB 64bit IO Format: ...