首页 > 编程知识 正文

Linux bash命令sed命令以及语法,linux常用命令和语法

时间:2023-05-03 06:27:25 阅读:235779 作者:4725

sed文本处理工具 说明:

1.从文件中读取数据,StreamEDitor流(行)编辑器,逐行处理文本;
Sed 是一个脚本型的编译器,是非交互式的编辑器

2.模式空间(将一行数据加载到内存,进行处理),默认不编辑源文件,仅对模式空间中的数据处理,将处理的数据输出到屏幕

用法:一般用法:sed [-neri] '指令' file...sed -f scriptsfile file...选项:-n 安静模式,只有经过Sed处理的行才显示出来,其他不显示-e 表示直接在命令行模式上进行Sed操作(默认选项); 进行多项编辑,即对输入行应用多条sed命令时使用-f 将Sed的操作写在一个文件里,用的时候“-f filename”就可以按照内容进行Sed操作-r 使Sed支持扩展正则表达式(预设支持基础正则表达式)-i 直接修改读取的文件内容,而不是输出到终端sed 编辑指令的格式如下 : [address1[,address2]]function[argument]==addres (指定需要操作的行)==1. n1,n2 例:1,100 表示1至100行n1行开始,n2行结束处理n1行开始到n2行结束的数据$符号表示文件最后一行2. /RegExp/匹配正则表达式处理正则表达式匹配的行的数据3. /pattern1/,/pattern2/pattern1匹配到为行开始pattern2匹配到为行结束处理pattern1,到pattern2之间所有行数据4. n指定第n行的处理指定第n行的数据5. n1,+n n1 为行开始+n 开始行向后n行处理行开始到向后n行的数据==function(可对数据处理的动作(sed内定函数))==d 删除符合条件的行D 删除模板块的第一行h 拷贝模板块的内容到内存中的缓冲区H 追加模板块的内容到内存中的缓冲区g 获得内存缓冲区的内容,并替代当前模板块中的文本G 获得内存缓冲区的内容,并追加到当前模板块文本的后面p 显示符合条件的行P (大写) 打印模板块的第一行q 退出Sedl 列表不能打印字符的清单n 读取下一个输入行,用下一个命令处理新的行而不是用第一个命令。N 追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码a "string" 在指定的行后面追加新行,内容为"string"i "string" 在指定的行前面插入新行,内容为"string"c "string" 将处理的数据行,取代内容为"string"r file 将指定文件的内容天骄到符合条件的行后w file 将指定范围内的内容另存至指定的文件中W file (大写)写并追加模板块的第一行到file末尾。s/pattern/string/修饰符 查找并替换,默认只替换每行第一次被模式匹配到的字符串修饰符:g 表示行内全面替换。 p 表示打印行。 w 表示把行写入一个文件。 x 表示互换模板块中的文本和缓冲区中的文本。 y 表示把一个字符翻译为另外的字符(但是不用于正则表达式)1 子串匹配标记& 已匹配字符串标记i 忽略大小写特别说明: s///,s###,s@@@都可以,当所使用的分割符号与内容中显示的相同时,需使用转义字符转义 ,1,2:成组匹配,1表示匹配第一个‘(’,2表示匹配第二个‘(’b lable 分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾t label if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾T label 错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾 ! 表示后面的命令对所有没有被选定的行发生作用。 = 打印当前行号码。 # 把注释扩展到下一个换行符以前 实例使用

sed -en filename 显示文件内容

关于替换的一些实际操作


测试文本

aaa AAA bbb BBBccc CCCddd DDDHello World!hello world!HELLO WORLD!heLLO wORld!I love you

操作截图:







版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。