Linux中文本处理命令sed的使用示例分享

作者&投稿:彘乐 (若有异议请与网页底部的电邮联系)
~ sed对文本的处理很强大,并且sed非常小,参数少,容易掌握,他的操作方式根awk有点像。sed按顺序逐行读取文件。然后,它执行为该行指定的所有操作,并在完成请求的修改之后的内容显示出来,也可以存放到文件中。完成了一行上的所有操作之后,它读取文件的下一行,然后重复该过程直到它完成该文件。在这里要注意一点,源文件(默认地)保持不被修改。sed 默认读取整个文件并对其中的每一行进行修改。说白了就是一行一行的操作。我用sed主要就是用里面的替换功能,真的很强大。下面以实例,详细的说一下,先从替换开始,最常用的。
参数
sed -h
-n, --quiet, --silent 取消自动打印模式空间
-e 脚本, --expression=脚本 添加“脚本”到程序的运行列表
-f 脚本文件, --file=脚本文件 添加“脚本文件”到程序的运行列表
--follow-symlinks 直接修改文件时跟随软链接
-i[扩展名], --in-place[=扩展名] 直接修改文件(如果指定扩展名就备份文件)
-l N, --line-length=N 指定“l”命令的换行期望长度
--posix 关闭所有 GNU 扩展
-r, --regexp-extended 在脚本中使用扩展正则表达式
-s, --separate 将输入文件视为各个独立的文件而不是一个长的连续输入
-u, --unbuffered 从输入文件读取最少的数据,更频繁的刷新输出
--help 打印帮助并退出
--version 输出版本信息并退出
例1
测试文件
代码如下:
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
daemon:x:2:2:daemon:/sbin:/bin/false
mail:x:8:12:mail:/var/spool/mail:/bin/false
ftp:x:14:11:ftp:/home/ftp:/bin/false
nobody:$:99:99:nobody:/:/bin/false
zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
http:x:33:33::/srv/http:/bin/false
dbus:x:81:81:System message bus:/:/bin/false
hal:x:82:82:HAL daemon:/:/bin/false
mysql:x:89:89::/var/lib/mysql:/bin/false
aaa:x:1001:1001::/home/aaa:/bin/bash
ba:x:1002:1002::/home/zhangy:/bin/bash
test:x:1003:1003::/home/test:/bin/bash
@zhangying:*:1004:1004::/home/test:/bin/bash
policykit:x:102:1005:Po
例a,这个例子,把test文件中的root替换成tankzhang,只不过只替换一次及终止在这一行的操作,转到下一行
代码如下:
[zhangy@BlackGhost mytest]# sed 's/root/tankzhang/' test |grep tank
tankzhang:x:0:0:root:/root:/bin/bash
例b,这个例子,用tankzhang把文件test中的root全部替换掉,请注意g这个字母,global的缩写
代码如下:
[zhangy@BlackGhost mytest]# sed 's/root/tankzhang/g' test |grep zhang
tankzhang:x:0:0:tankzhang:/tankzhang:/bin/bash
zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
ba:x:1002:1002::/home/zhangy:/bin/bash
@zhangying:*:1004:1004::/home/test:/bin/bash
例c,加了-n p后表示只打印那些发生替换的行(部分替换),上面的例子,我并没有加上grep
代码如下:
[zhangy@BlackGhost mytest]# sed -n 's/root/tankzhang/p' test
tankzhang:x:0:0:root:/root:/bin/bash
例d,加了-n pg后表示只打印那些发生替换的行(全部替换),上面的例子,我并没有加上grep
代码如下:
[zhangy@BlackGhost mytest]# sed -n 's/root/tankzhang/pg' test
tankzhang:x:0:0:tankzhang:/tankzhang:/bin/bash
例e,在第二行,到第八行之间,替换以zhang开头的行,用ying来替换,并显示替换的行
代码如下:
[zhangy@BlackGhost mytest]# cat test | sed -ne '2,8s/^zhang/ying/gp'
yingy:x:1000:100:,,,:/home/zhangy:/bin/bash
例f,当有多个命令要执行时,可以用分号来分开,并且分隔符可以自定义,默认是/。上面的例子意思是在第二行,到第八行之间,替换以zhang开头的行,用ying来替换,在5,到10间,用goodbay来替换dbus,并显示替换的行
代码如下:
[zhangy@BlackGhost mytest]# cat test | sed -n '2,8s/^zhang/ying/gp;5,10s#dbus#goodbay#gp'
yingy:x:1000:100:,,,:/home/zhangy:/bin/bash
goodbay:x:81:81:System message bus:/:/bin/false
例g,这个例子根上面的那个例子一样,只不过有一点不同,那就是-e来充当了分号的作用,-e也能分割多个命令。
代码如下:
[zhangy@BlackGhost mytest]# cat test | sed -ne '2,8s/zhang/ying/gp' -ne '5,10s#dbus#goodbay#gp'
yingy:x:1000:100:,,,:/home/yingy:/bin/bash
goodbay:x:81:81:System message bus:/:/bin/false
例h,正则的用法,在sed里面用括号的话要加上的,不然会报错的。
代码如下:
[zhangy@BlackGhost mytest]# sed -ne '2,8s/^(zhangy)/1ing/gp' test
zhangying:x:1000:100:,,,:/home/zhangy:/bin/bash
[root@masters ~]# sed -ne '2,8s/^(zhangy)/ing/gp' test
zhangying:x:1000:100:,,,:/home/zhangy:/bin/bash
例i,的用处是,在找到的字符串后加上后面的字符串,zhang后都加上了ying
代码如下:
[zhangy@BlackGhost mytest]# sed -ne '2,15s/zhang/ying/gp' test
zhangyingy:x:1000:100:,,,:/home/zhangyingy:/bin/bash
ba:x:1002:1002::/home/zhangyingy:/bin/bash
@zhangyingying:*:1004:1004::/home/test:/bin/bash
例j,这个例子是说,在以zhang开头的行开始,到匹配Po的行结束,在他们之间进行替换
代码如下:
[zhangy@BlackGhost mytest]# sed -ne '/^zhang/,/Po/s/zhang/ying/gp' test
yingy:x:1000:100:,,,:/home/yingy:/bin/bash
ba:x:1002:1002::/home/yingy:/bin/bash
@yingying:*:1004:1004::/home/test:/bin/bash
例k,n;这里的n是next的缩写,找到root的行后,将其下一行的中的bin换成tank
代码如下:
[zhangy@BlackGhost mytest]$ sed '/root/{n;s/bin/tank/}' test
root:x:0:0:root:/root:/bin/bash
tank:x:1:1:bin:/bin:/bin/false
例m,y的作用是将匹配的字符换成大写,不过替换字符和被替换字符长度要一样
代码如下:
[zhangy@BlackGhost mytest]$ sed -e '1,2y/root/ROOT/' test
ROOT:x:0:0:ROOT:/ROOT:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
例n,h的作用是将找到的行,放到一个缓存区,G的作用是将缓存区中的内容放到最后一行
代码如下:
[zhangy@BlackGhost mytest]$ sed -e '/root/h' -e '$G' test
................................
.............................
ba:x:1002:1002::/home/zhangy:/bin/bash
test:x:1003:1003::/home/test:/bin/bash
@zhangying:*:1004:1004::/home/test:/bin/bash
root:x:0:0:root:/root:/bin/bash
例o,行替换,用匹配root的行,来替换匹配zhangy的行
代码如下:
[zhangy@BlackGhost mytest]$ sed -e '/root/h' -e '/zhangy/g' test
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
daemon:x:2:2:daemon:/sbin:/bin/false
mail:x:8:12:mail:/var/spool/mail:/bin/false
ftp:x:14:11:ftp:/home/ftp:/bin/false
nobody:$:99:99:nobody:/:/bin/false
root:x:0:0:root:/root:/bin/bash
http:x:33:33::/srv/http:/bin/false
dbus:x:81:81:System message bus:/:/bin/false
hal:x:82:82:HAL daemon:/:/bin/false
mysql:x:89:89::/var/lib/mysql:/bin/false
aaa:x:1001:1001::/home/aaa:/bin/bash
root:x:0:0:root:/root:/bin/bash
test:x:1003:1003::/home/test:/bin/bash
root:x:0:0:root:/root:/bin/bash
例p,这个例子是说,在以zhang开头的行开始,到匹配Po的行结束,在他们之间进行替换
代码如下:
[zhangy@BlackGhost mytest]# sed -ne '/^zhang/,/Po/s/zhang/ying/gp' test
yingy:x:1000:100:,,,:/home/yingy:/bin/bash
ba:x:1002:1002::/home/yingy:/bin/bash
@yingying:*:1004:1004::/home/test:/bin/bash
例q,3q的意思是到第三行的时候,退出
代码如下:
[zhangy@BlackGhost mytest]$ sed -e 's/bin/tank/g;3q' test
root:x:0:0:root:/root:/tank/bash
tank:x:1:1:tank:/tank:/tank/false
daemon:x:2:2:daemon:/stank:/tank/false
例r,特殊匹配
匹配数字别忘了中括号外面还有一个中括号。
[:alnum:] 字母数字 [a-z A-Z 0-9]
[:alpha:] 字母 [a-z A-Z]
[:blank:] 空格或制表键
[:cntrl:] 任何控制字符
[:digit:] 数字 [0-9]
[:graph:] 任何可视字符(无空格)
[:lower:] 小写 [a-z]
[:print:] 非控制字符
[:punct:] 标点字符
[:space:] 空格
[:upper:] 大写 [A-Z]
[:xdigit:] 十六进制数字 [0-9 a-f A-F]
代码如下:
[zhangy@BlackGhost mytest]# sed -ne '2,15s/zhangy.*[[:digit:]]/=======/gp' test
=======:,,,:/home/zhangy:/bin/bash
@=======::/home/test:/bin/bash
例2
例a,删除1,14行
代码如下:
[zhangy@BlackGhost test]$ sed -e '1,14d' test
@zhangying:*:1004:1004::/home/test:/bin/bash
policykit:x:102:1005:Po
例b,删除4以后的行,包括第4行,把$当成最大行数就行了。
代码如下:
[zhangy@BlackGhost mytest]$ sed -e '4,$d' test
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
daemon:x:2:2:daemon:/sbin:/bin/false
例c,删除包括false的行,或者包括bash的行,别忘了加
代码如下:
[zhangy@BlackGhost mytest]$ sed -e '/(false|bash)$/d' test
policykit:x:102:1005:Po
例d,删除从匹配root的行,到匹配以test开头的行,中间的行
代码如下:
[zhangy@BlackGhost mytest]$ sed -e '/root/,/^test/d' test
@zhangying:*:1004:1004::/home/test:/bin/bash
policykit:x:102:1005:Po
例3
例a,读取test2的内容,并将其写入到匹配行的下面
代码如下:
[zhangy@BlackGhost mytest]$ sed -e '/^root/r test2' test
root:x:0:0:root:/root:/bin/bash
=============
-------------
+++++++++++++
bin:x:1:1:bin:/bin:/bin/false
daemon:x:2:2:daemon:/sbin:/bin/false
例b,将匹配数字的行,写入test2中
代码如下:
[zhangy@BlackGhost mytest]$ sed '/[[:digit:]]/w test2' test
例c,将要插入的东西,插入匹配行的下面
代码如下:
[zhangy@BlackGhost mytest]$ sed '/root/a\ ===aaaa====' test
root:x:0:0:root:/root:/bin/bash
===aaaa====
bin:x:1:1:bin:/bin:/bin/false
例d,正好根a相反,将要插入的东西,插入到匹配行的上面
代码如下:
[zhangy@BlackGhost mytest]$ sed '/^daemon/i\=================' test
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
=================
daemon:x:2:2:daemon:/sbin:/bin/false
mail:x:8:12:mail:/var/spool/mail:/bin/false
例4
#取得一个文件(或目录)路径的父目录,s@@@为替换格式,(/.*/)是指一个"/"后面跟了任意字符又跟了一个"/",其中()是用来把匹配内容作为一个整体后向引用,[^/]{1,}是指一个非"/"字符出现了一次,两次,或多次;/?是指"/"出现了0次或1次,1是后向引用前面匹配的内容
代码如下:
[root@practice ~]# echo "/usr/local/bin/" |sed 's@(/.*/)[^/]{1,}/?@1@'
/usr/local/
#使用扩展正则表达式后,亦可如此:
[root@practice ~]# echo "/etc/rc.d/rc.sysinit" | sed -r 's@(/.*/)[^/]+/?@1@'
/etc/rc.d/


linux 文本处理工具之一grep命令详解
grep(Globel Search Regular Expression and Printing out the line)全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,是一个对行进行操作的搜索工作,它能使用正则表达式搜索文本,并把匹配的行打印出来。Unix的grep家族包括grep、egrep和fgrep。 egrep表示扩展的grep,相比grep支持更多的元字符,"grep -E"相当...

Linux文本处理命令简介
Linux环境中的文本处理工具为我们的日常操作提供了强大的支持。其中,sort命令是一个不可或缺的工具。它的主要职责是对文本文件中的每一行数据进行有序排列,无论是按照字母顺序、数字大小还是自定义规则,sort都能准确地完成这项任务。只需在命令行中输入如"sort filename",它就会对文件内容进行整理,...

Linux文本处理命令uniq命令
uniq命令的语法如下:uniq [选项] 文件 它的基本功能是逐行比较输入文件,通常情况下,除了第一个出现的行,其余重复的行会被删除。行间的比较依据字符集的默认排序规则进行。处理结果会输出到另一个指定的输出文件中,但输入文件和输出文件不能相同。如果输入文件使用“-”表示,uniq将从标准输入读取内容。

Linux下使用Shell文本处理工具集锦
  字符串插入字符:将文本中每行内容(PEKSHA) 转换为 PEK\/SHA sed 's\/^.\/{3\/}\/\/\/g' file awk 数据流处理工具 awk脚本结构   awk ' BEGIN{ statements } statements2 END{ statements } ' 工作方式   1.执行begin中语句块;   2.从文件或stdin中读入一行,然后执行statements2,重复...

Linux文本处理命令Sort命令
Linux中的sort命令是一个强大的文本处理工具,用于对文件内容进行各种排序操作。它的基本功能是根据指定的排序规则,逐行对文件中的数据进行排序。默认情况下,sort会按ASCII字符顺序对整行内容进行排序,但如果提供了相应的选项,可以调整排序规则和行为。sort命令的语法为sort [选项] 文件,如果没有指定输入...

Linux的命令行中一些文本操作技巧的实例分享
把文件中所有的 "find" 文本替换为 "search":代码如下: sed "s\/find\/search\/g" grephelp.txt这条命令中,s 表示执行“替换操作”,\/find\/search\/ 表示把 "find" 替换为 "search",g 表示对一行中所有的匹配进行替换。sed 默认把处理结果打印到标准输出,我们可以通过重定向把处理结果转储到一个新文件中,或者...

Linux系统中tr命令删除和替换文本字符的基本用法
tr用来从标准输入中通过替换或删除操作进行字符转换。tr主要用于删除文件中控制字符或进行字符转换。使用tr时要转换两个字符串:字符串1用于查询,字符串2用于处理各种转换。tr刚执行时,字符串1中的字符被映射到字符串2中的字符,然后转换操作开始。带有最常用选项的tr命令格式为:代码如下:tr -c -d -...

linux中批量查找替换文本内容例子
2.批量查找并替换文件内容。sed -i "s\/要找查找的文本\/替换后的文本\/g" `grep -rl "要找查找的文本" .\/`sed的其他用法如下:1、删除行首空格 sed 's\/^[ ]*\/\/g' filename sed 's\/^ *\/\/g' filename sed 's\/^[[:space:]]*\/\/g' filename 2、行后和行前...

Linux必须学会的60个命令:文件处理1
Linux文件系统具有良好的结构,系统提供了很多文件处理程序。这里主要介绍常用的文件处理命令。 file 1.作用file通过探测文件内容判断文件类型,使用权限是所有用户。 2.格式file [options]文件名3.[options]主要参数-v:在标准输出后显示版本信息,并且退出。 -z:探测压缩过的文件类型。 -L:允许符合连接。 -f name:...

Linux下常用文本处理命令
Linux下面有很多经典的非常有用的命令,其中处理文本的命令就有很多。下面就让我们一起看看这些经典的Linux文本处理命令有哪些吧。一. sort 文件排序, 通常用在管道中当过滤器来使用. 这个命令可以依据指定的关键字或指定的字符位置, 对文件行进行排序. 使用-m选项, 它将会合并预排序的输入文件. 想...

彭阳县19562719535: linux里面的sed命令怎么用,做什么的?请详细说明 -
刁裕喜欣: sed 编辑器是 Linux 系统管理员的工具包中最有用的资产之一 Linux 操作系统最大的一个好处是它带有各种各样的实用工具.存在如此之多不同的实用工具,几乎不可能知道并了解所有这些工具.可以简化关键情况下操作的一个实用 工具是 sed...

彭阳县19562719535: linux中sed命令如何运用'\ ' 反斜杠 -
刁裕喜欣: 路径"../syslog/tmp/"替换为"/data/syslog/tmp”首先要搞清楚,转义符\的作用是消除有特殊含义字符的特殊意义,使其还原为普通字符. sed -i 's/\.\.\/syslog\/tmp\//\/data\/syslog\/tmp/' file.ini 点号.在正则表达式中有其特殊含义(表示任意一个字...

彭阳县19562719535: linux下的sed命令使用? -
刁裕喜欣: sed 默认输出结果,不修改文件.而且这里的输入是管道.这样做:cat a.conf |grep '/'|sed 's/oracle/orcl/g' > tmp.conf mv tmp.conf a.conf

彭阳县19562719535: linux命令sed与awk是干什么用的,怎么用? -
刁裕喜欣: 非常强大的文本操纵工具,sed,awk,grep 这个三个命令 都是操作文本文件的 unix系统有几个非常命令的特点: 1. 对于内核而言,unix文件都是字节序列.io设备也是文件. 2. 至于文件的含义交由应用程序来解释.其中文本文件非常重要,因为...

彭阳县19562719535: 求在linux下SED命令的正则使用方法
刁裕喜欣: 如果文本内容是如下形式 id:0 id:2 id:3 id:7 可以用cat a.txt | sed -e 's/id://g'

彭阳县19562719535: Linux:如何使sed指令生效呢?默认只是显示了而已,没有效果啊 -
刁裕喜欣: sed 's/^/Demo:/' test 只对文本处理后显示在终端上,编辑后的文本没有保存,使用sed 's/^/Demo:/' test > test1 看看

彭阳县19562719535: linux sed 的使用 -
刁裕喜欣: # cat test.txt123?4344?re fda?er# sed 's/\?.*//g' test.txt123344 fda"?" 在sed中是通配符代表一至多个任意字符,而“*”是代表任意字符.所以在要“?”之前价格转义符“\”,这样才能匹配到字符“?”而不是通配符“?”.如果不加“g”的话只替换一行,加上“g”就每行都替换.

彭阳县19562719535: linux命令 sed 请问有哪位大大知道这个sed 命令是什么意思吗? sed 's/\//\\\//g' -
刁裕喜欣: 截取或修改字符串,打印到屏幕上. 使用方法:sed 参数 '动作' 动作对象 如果用-i参数将修改文档的内容,你的sed 's/\//\\\//g'这个我举一个类似的再分析你的. sed 's/old/new/g' *** 这个就是把***文档里面的old这个词换成new这个词. 你的sed ...

彭阳县19562719535: 关于linux 里sed的用法与正则表达式? -
刁裕喜欣: 题主你好,这道题的关键点在于: " [a]* 表示匹配0个或多个a "" 多个a "好理解,但" 0个a "可能就是你不理解的地方,说白了" 0个a "匹配的是位置而并不是某个字符, " 0个a "故名思议嘛: " 没有a的地方 "------------------- 下来咱看...

彭阳县19562719535: Linux中sed命令的使用? dog cat dog pig dog linux dog unix
刁裕喜欣: just a workaround, not perfect:sed 's/[^^]dog/ pig/'

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网