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有其信息(它的数 ...
随机推荐
- Android学习之简单的数据存储
在Android中,数据存储是开发人员不可以避免的.Android为开发者提供了很多的存储方法,在前面的博客中,已经讲述了sqlite存储数据.今天将介绍用SharedPreferences来存储数据 ...
- sqlserver 2008 局域网跨服务器T-SQL操作(一)
--查看当前链接情况: select * from sys.servers; --增加链接,参数:服务器别名,为链接服务器的OLE DB数据源的产品名称,与此数据源对应的OLE DB访问接口的唯一编程 ...
- [Linked List]Reverse Linked List,Reverse Linked List II
一.Reverse Linked List (M) Reverse Linked List II (M) Binary Tree Upside Down (E) Palindrome Linked ...
- jmake 编译当前目录c/c++单文件 指定文件 可加选项
基础版本的jmake是将所有当前文件夹下的C/C++文件生成单文件编译命令,并且jmake命令不可加选项. 现在做的改进是能在输入命令jmake时加上一些选项了,‘-’开头的选项加入到每个编译单文件的 ...
- Tomjson - json 解析库
Tomjson - 一个"短小精悍"的 json 解析库 Tomjson,一个"短小精悍"的 json 解析库,tomjson使用Java语言编写,主要作用是把 ...
- 用做网页开发经历了三个阶段(附长篇讨论) good
用做网页开发经历了三个阶段:第一阶:傻干阶段使用Intraweb,傻瓜型,无需知道javascript,html,css,会pascal就可以了. 第二阶:困惑阶段使用Intraweb,有很多限制,比 ...
- 震撼,强烈推荐 OrangeUI For FireMonkey
今天,高勇上传了一个演示rtx for kbmMW的android应用,我下载测试,被实际的效果给震惊了!万万想不到的,用OrangeUI做的一个List列表,数据通过远程查询,运行效果在我看来,达到 ...
- WF编译报错
最近在研究WF的时候,遇到了一个未知的错误,错误信息时这样的 错误 102 扩展“Microsoft.Activities.Build.Validation.ValidationBuildExtens ...
- 如何在你的project中使用support library【转】
Android support library是google以jar包形式提供的一个代码库,里面包含一些向后兼容的framework API以及一些只有在这个library中才提供的feature. ...
- uva 10972 RevolC FaeLoN cdoj 方老师和农场
//自己写的第一发tarjan 解:先进行双连通分解并缩点,分解后一定是一颗树,设叶节点个数为n那么答案就是(n+1)/2 关于双连通分量求解:在跑tarjan时判断每个点连向父节点的边是否是桥,如果 ...