`

sed学习笔记

阅读更多

转自http://blog.zhangjianfeng.com/article/532

sed 编辑指令的格式如下 :
[address1[,address2]]function[argument]
#address1/2可为行数或regular expression, 函数参数 function[argument] 为 sed 的内定函数
#/apple/,/orange/d 表示删除含有 “apple” 至 “orange” 字符串的数据行

++函数参数 功能列表
: label 建立 script file 内指令互相参考的位置。
# 建立批注
{ } 集合有相同位址参数的指令。
! 不执行函数参数。
= 印出资料行数( line number )。
a\ 添加使用者输入的数据。
b label 将执行的指令跳至由 : 建立的参考位置。
c\ 以使用者输入的数据取代数据。
d 删除数据。
D 删除 pattern space 内第一个 newline 字母 \ 前的数据。
g 拷贝数据从 hold space。
G 添加资料从 hold space 至 pattern space 。
h 拷贝数据从 pattern space 至 hold space 。
H 添加资料从 pattern space 至 hold space 。
l 印出 l 资料中的 nonprinting character 用 ASCII 码。
i\ 插入添加使用者输入的数据行。
n 读入下一笔资料。
N 添加下一笔资料到 pattern space。
p 印出资料。
P 印出 pattern space 内第一个 newline 字母 \ 前的数据。
q 跳出 sed 编辑。
r 读入它檔内容。
s 替换字符串。
t label 先执行一替换的编辑指令 , 如果替换成牛p>则将编辑指令跳至 : label 处执行。
w 写资料到它文件内。
x 交换 hold space 与 pattern space 内容。
y 转换(transform)字符。

++ 函数参数 s 表示替换(substitute)文件内字符串。其指令格式如下 :
[address1[ ,address2]] s/pattern/replacemen/[flag]
#flag : 主要用它来控制一些替换情况 :
当 flag 为 g 时 , 代表替换所有符合(match)的字符串 。
当 flag 为十进制数 m 时 , 代表替换行内第 m 个符合的字符串。
当 flag 为 p 时 , 代表替换第一个符合 pattern 的字符串后 , 将数据输出标准输出文件。
当 flag 为 w wfile 时 , 代表替换第一个符合 pattern 的字符串后 , 输出到 wfile 檔内(如果 wfile 不存在 , 则会重新开启名为 wfile 的档案)。
#数据文件的 “test” 被替换成 “test my car”
sed -e ’s/test/& my car/’ filename ## &:代表其前 pattern 字符串
#数据文件的 “test my car” 被替换成 “[my car test]”
sed -e ’s/\(test\) \(my\) \(car\)/[\2 \3 \1]/’ filename #\n代表pattern中被第 n 个 \(XX\)所括起来的字符串

++参数 p 可以显示符合条件行
sed -n ‘1p;5p’ filename #显示filename的第1行和第5行
sed -n ‘1p,5p’ filename #显示filename的第1行到第5行
sed -n ‘/中国人/p’ filename #显示filename中所有含有”中国人”字段的行

++函数参数 d 表示删除数据行 , 其指令格式如下:
[address1[ ,address2]] d

++函数参数 a 表示将资料添加到文件中。其指令格式如下:
[address1] a\ 使用者所输入的数据
sed -e ‘/美国人/a\中国人’ filename #添加 “中国人” 在含 “美国人” 字符串的数据行后
#如果需要插入多行,可以加\n

++函数参数 i 表示将资料插入文件中。其指令格式如下:
[address1] i\ 使用者所输入的数据
sed -e ‘/美国人/i\中国人’ filename #添加 “中国人” 在含 “美国人” 字符串的数据行前

++函数参数c 表示将以使用者输入的数据取代数据。其指令格式如下:
[address1] c\ 使用者所输入的数据
sed -e ‘/美国人/c\中国人’ filename #将 “中国人” 所在行数据更换为 “美国人” 字符串

++&可以在行内替换指定关键字
sed -e ’s/美国人/中国人/’ filename #将 “中国人” 所在行中,”中国人”更换为 “美国人”

++函数参数 r 表示读入它档案内容到檔中。其指令格式如下 :
[address1] r 它檔名称
sed’/美国人/r otherfile/’ filename #将otherfile文件内容附加到所有含”美国人”行的下面

++函数参数 w 表示将檔中的写到它檔内。其指令格式如下 :

[address1[ ,address2]] w 它檔名称

++函数参数 y 表示转换数据中的字符。其指令格式如下 :
[address1[ ,address2]]y /xyz…/abc…/
#其中 abc… 与 xyz… 的字符个数必须相同,a字符转换成x字符、b转成y、c转成z…
sed -e ‘y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/’ input.dat #字母大小的转换。

++函数参数 ! 表示不执行函数参数。当有如下指令时 ,
[address1[ , address2]] ! 函数参数
sed -e ‘/1996/!d’ input.dat #删除 除了含 “1996″ 字符串外的所有行

++参数n表示读入下一行资料。其指令格式如下:
[address1[ ,address2]] n
sed -n -e ‘n’ -e ‘p’ infro.dat #输出 input.dat 文件内偶数行资料

++函数参数 q 表示跳离 sed 。其指令格式如下:
[address1] q

++函数参数 = 表示印出资料的行数。其指令格式如下:
[address1 ,[address2]] =
sed -e ‘=’ input.dat #印出资料的行数

++ 函数参数#后的文字为注解,当注解超过多行时,其行间须以”\”换行字符相隔

++函数参数 N 表示添加下一笔资料在 pattern space 内。其指令格式如下:
[address1 ,[address2]] N
#将下述两行数据合并。假设 input.dat 的内容如下 :
#The UNIX
#Operating System
sed -e ‘N’ -e ’s/\n/ /’ input.dat

++函数参数 D 表示删除 pattern space 内的第一行资料。其指令格式如下:
[address1,address2]D
#函数参数 D 与 d 的比较如下 :
当 pattern space 内只有一数据行时 , D 与 d 作用相同。
当 pattern space 内有多行资料行时
D 表示只删除 pattern space 内第一行资料 ; d 则全删除。
D 表示执行删除后 , pattern space 内不添加下一笔数据 , 而将剩下的数据重新执行 sed script ; d 则读入下一行后执行 sed script。

++函数参数 P 表示印出 pattern space 内的第一行资料。其指令格式如下:
[address1,address2] P

++输出 input.dat 文件内奇数行资料。假设 input.dat 檔内容如下:
#The
#UNIX
#System
sed -n -e ‘N’ -e ‘P’ infro.dat
#说明: 在命令列上
#以选项 -n , 将数据输出的控制权(参照[section2.5])转给指令。
#利用函数参数 N 将偶数行添加至 pattern space 内奇数行后。
#利用函数参数 P 将 pattern space 内的第一行(奇数行)输出。
#在奇数行输出后 , pattern space 内剩下的数据行(偶数行)则被放弃输出。最后 , 整个输出只有原先的奇数行数据。

++函数参数 h 表示暂存 pattern space 的资料至 hold space。其指令格式如下:
[address1 ,[address2]] h
#函数参数H与h唯一差别是,sed执行h时,数据盖掉(overwrite) hold space内原来的数据,而H,数据则是”添加(append)”在 hold space 原来数据后.

++函数参数 g 表示与函数参数 h 相反的动作 , 它表示将 hold space 内资料放回 pattern space 内。其指令格式如下 :
[address1,address2]g
#函数参数G与g唯一差别是,sed 执行g时,数据盖掉(overwrite) pattern space内原来的数据,而G,数据则是”添加(append)”在 pattern space原来数据后.

++函数参数 x 表示交换 hold space 与 pattern space 内的数据。其指令格式如下 :
[address1 ,[address2]] x
sed -e ‘1h’ -e ‘3x’ input.dat #将 input.dat 文件内第 1 行资料取代第 3 行资料
#以函数参数 h 将第 1 资料存入 hold space ; 当第 3 行数据出现在 pattern space , 以函数参数 x 交换 hold space 与 pattern space 的内容。如此 , 第 3 行资料就被第 1 资料替代。

++ b、:label
函数参数 : 与函数参数 b 可在 sed script 内建立类似 BASIC 语言中 GOTO 指令的功能。其中 , 函数参数 : 建立标记;函数参数 b 将下一个执行的指令 branch 到标记处执行。函数参数 : 与 b , 在 script file 内配合的情况如下
编辑指令m1
:记号
编辑指令m2
[address1,[address2]]b [记号]
其中 , 当 sed 执行至指令 [address1,[address2]]b [记号] 时 , 如 pattern space 内的数据符合地址参数 , 则 sed 将下一个执行的位置 branch 至由 :记号(批注[14])设定的标记处 , 也就是再由 “编辑指令m2″ … 执行。另外 , 如果指令中函数参数 b 后没有记号 , 则 sed 将下一个执行的指令 branch 到 script file 的最后 , 利用此可使 sed script 内有类似 C 语言中的 case statement 结构。
#将 input.dat 文件内数据行的开头字母重复印 40 次。假设 input.dat 檔的内容如下 :
A
B
C
#sed 命令列如下 :
sed -e ‘{
:p1
/A/s/A/AA/
/B/s/B/BB/
/C/s/C/CC/
/[ABC]\{40\}/b
b p1
}’ input.dat

++基本上 , 函数参数 t 与 函数参数 b 的功能类似 , 除了在执行 t 的 branch 前 , 会先去测试其前的替换指令有没有执行替换成功外。在 script file 内的情况如下:
编辑指令m1
:记号
编辑指令m2
s/…/…/
[address1,[address2]]t [记号]
编辑指令m3
其中 , 与函数参数 b 不同处在于 , 执行函数参数 t branch 时 , 会先检查其前一个替换指令成功与否。如成功 , 则执行 branch ; 不成功 , 则不 branch , 而继续执行下一个编辑指令
##将 input.dat 文件中资料 A1 替换成 C1、C1 替换成 B1、B1 替换成 A1。input.dat 檔的内容如下:
代号
B1
A1
B1
C1
A1
C1
说明 : input.dat 文件中全部数据行只需要执行一次替换动作 , 但为避免数据被替换多次 , 所以利用函数参数 t 在 sed script 内形成一类似 C 语言中 case statement 结构 , 使每行数据替换一次后能立即用函数参数 t 跳离替换编辑。
sed 命令列 :
sed -e ‘{
s/A1/C1/
t
s/C1/B1/
t
s/B1/A1/
t
}’ input.dat

++常用的 regular expression
普通字符 由普通字符所组成的 regular expression 其意义与原字符串字面意义相同。
^字符串 限制字符串必须出现于行首 。
$字符串 限制字符串必须出现行尾。
. 表示任意一字符。
[...] 字符集合, 用以表示两中括号间所有字符当中的任一个 ,如 [^...]表示两中括号间所有字符以外的字符。
-& 字符集合中可用”&”指定字符的范围。
* 用以形容其前的字符(或字符集合)可重复任意多次 。
\n 表示嵌入新行字符(imbedded new line character)。
\(…\) 于 regular expression 中使用”\(” “\)”来括住一部份的 regular expression ; 其后可用”\1″来表示第一个被”\(” “\)”括住的部份。若 regular expression 中使用数次的”\(” “\)”来括住不同的部份 , 则依次使用”\1″,”\2″,”\3″,…(最多可到”\9″)。

分享到:
评论

相关推荐

    Sed学习笔记

    Sed学习笔记

    linux shell Sed学习笔记

    linux shell Sed学习笔记.相信你看完会明白的

    sed与awk(第二版)学习笔记

    sed与awk(第二版)学习笔记

    sed高级用法学习笔记和实例

    根据个人平时多年的学习积累,总结的sed所有用法,包括sed中删除,修改,添加,插入,合并,交换,读入,替换,跳转,标签,转换等高级用法!

    老男孩老师-Linux正则表达式实战 学习笔记

    根据老男孩老师视频教程《Linux正则表达式实战》的精彩讲解,进行了学习笔记记录,主要讲解Linux三剑客中的grep用法、捎带sed的讲解笔记。 学习笔记进行了规整,相信Linux运维工作者能够一目了然笔记的内容。 (1...

    Linux学习笔记【博文整理系列】

    学习linux的笔记,发到博文了,鉴于文档方便保存和查阅,发出来,免费的哈 博文来自http://blog.csdn.net/wklken,共12篇,类似手册,可快速练习和查阅,容易上手 文档列表: Linux笔记——vim常用操作及扩展补充...

    一些sed命令

    压缩包里包含有一个word文档,说我平时使用sed命令的记录,一个学习笔记,还有一个sed使用手册。sed是个强大的流编辑器,灵活使用可以减少很多麻烦。

    Shell脚本学习笔记

    第7章 sed、gawk介绍与正则表达式 120 7.1 sed编辑器 120 7.1.1 在命令行中定义编辑器命令 120 7.1.2 在命令行中使用多个编辑器命令 121 7.1.3 从文件读取编辑器命令 121 7.2 gawk程序 122 7.2.1 gawk命令格式 122 ...

    shell基础+sed+awk的使用

    学习shell时做的笔记,包含sed,awk,sort,uniq的使用

    《Unix Shell 实例精解》学习笔记

    《Unix Shell 实例精解》学习笔记 第一章 关于UNIX Shell的介绍 第2章 UNIX工具箱 第3章 grep家族 第4章 流编辑器(sed) 第5章 awk 实用程序:awk作为一种UNIX工具 第6章 awk实用程序:awk编程结构 ...

    《unix_shell_实例精解》学习笔记

    shell编程宝典非常实用的shell编程开发资料,详细的sed,awk。grep的用法。

    sed 与 awk(第二版)

     本笔记参考书籍《sed 与 awk(第二版)》书中的重点部分基本都已记录在笔记中。  笔记摘录了书中较多示例,以及来自网络的示例辅助学习。  笔记中的示例已制作成文件存放在 testfile 文件夹中,可上传至 ...

    guo-cheng#Learning-notes-2021#Linux学习笔记1

    第二列按数值大小排序 第二列相同的再按第一列的字母顺序的逆序排序(-r) 第一步所有行变为一行,这一步使用tr 是因为tr里面可以直接识别换行符,而sed不可以

    Shell正则表达式学习笔记

    正规表示法并不是一个工具程序, 而是一个字符串处理的标准依据,如果您想要以正规表示法的方式处理字符串,就得要使用支持正规表示法的工具程序才行, 这类的工具程序很多,例如 vi, sed, awk 等等。 一、正则...

    Linux的常用命令cat、sed、zip等用法,以及shell编程的基本语法,以及makefile编写方式等等

    这个是我在学习Linux的时候做的思维导图笔记,主要是Linux的一些基础知识。免费提供下载,学习分享。 该文档分为以下几个部分: 1.shell语法:包含格式化输入输出、数组定义、变量定义方法、运算方法、流程控制、...

    Bootstrap教程JS插件弹出框学习笔记分享

    本文主要来学习一下JavaScript插件–弹出框。 案例 为页面内容添加一个小的覆盖层,就像iPad上的效果一样,为页面元素增加额外的信息。 先来看几个简单的静态案例效果图 效果比较简单主要就是静态的弹出的小窗体,...

    bash-study:shell学习笔记

    目录实战1、批量替换指定文件的指定内容涉及知识点:基础语法、grep 数据搜索、awk 数据提取、sed 数据修改。# 当然, grep 可以直接得到文件名的,这里作为演戏,先得到默认的匹配内容,然后使用awk处理得到文件名...

Global site tag (gtag.js) - Google Analytics