分类: LINUX
2016-11-04 18:05:05
在UNIX上使用sed命令进行字符串处理中常常遇到的问题就是行首行尾的空格怎么删除。 下面介绍sed是怎样实现的,当然awk同样可以。
1:行首空格
sed ‘s/^[ \t]*//g’
说明:
第一个/的左边是s表示替换,即将空格替换为空
第一个/的右边是表示后面的以xx开头 中括号表示“或”,空格或tab中的任意一种。
这是正则表达式的规范。 中括号右边是*,表示一个或多个。
第二个和第三个\中间没有东西,表示空 g表示替换原来buffer中的,sed在处理字符串的时候并不对源文件进行直接处理,先创建一个buffer,但是加g表示对原buffer进行替换 整体的意思是:用空字符去替换一个或多个用空格或tab开头的本体字符串
2:行末空格
sed ‘s/[ \t]*$//g’
和上面稍微有些不同是前面删除了^符,在后面加上了美元符,这表示以xx结尾的字符串为对象。
但是要注意在KSH中,Tab并不是\t而是直接打入一个Tab就可以了。
wolf点评:有空可以好好研究一下如何用sed将文本中的tab转换为空格!