百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

shell常用命令之sed用法介绍(shell中的seq命令)

liuian 2025-06-23 20:37 14 浏览

sed是Linux中一款强大流式文本处理工具,支持按行,按字段,按正则匹配进行文本的增删改查。以下是对sed用法的详细介绍:


一、sed的使用语法

调用sed的语法有两种:

1、在命令行指定sed指令对文本进行处理:sed [参数选项] sed指令 文件名称
2、在指令脚本中指定sed指令对文本进行处理:sed [参数选项] -f 指令脚本 文件名称 

二、sed常用选项

1. -r:解析扩展正则表达式(. * ? + ^ $ \ () {} [] [^])
2. -e: 将下一个参数解析为sed指令,只有当出现多个指令时才使用-e选项(指令脚本的另一种比较冗长的写法)
3. -n:取消默认输出,sed默认会输出所有内容,使用-n之后只会输出被处理过的行
4. -f script-file:指定sed要执行的脚本文件
5. -i[SUFFIX]:直接对源文件进行修改,如果使用了后缀,则会以指定的后缀备份源文件(原理:将sed命令输出内容直接重定向到源文件)                                        

三、sed中的编辑命令

1.a text:追加,向匹配行后面追加内容text
2.c text:替换,将匹配行整行替换为text
3.i text:插入,向匹配行前面插入内容text
4.d:伤处,删除匹配行的整行内容
5.s/source/target/g:替换,将匹配的内容source替换为目标内容target
6.p:打印,打印匹配的行,通常与-n一起使用
7.=:用来打印被匹配行的行号
8.n:读取下一行,遇到n时,会自动读取下一行
9.y/source/target/:字符转换,将source转换为target

四、sed命令操作实践

准备源文件内容如下:

1.向文件中添加或者插入行:a i

sed '3athis is a new line' sed_test.txt: 向第3行后面插入‘this is a new line’
sed '/disabled/athe last line of treasure made a disabled' sed_test.txt 向匹配‘/disabled/’的行后面追加内容
sed ‘/$athis is the end of this file/’sed_test.txt 向文件最后一行后面追加一行内容,$匹配最后一行
sed '3ithis is a new line' sed_test.txt	在第3行前面插入一行
sed '/disabled/ithe line of treasure made a disabled' sed_test.txt	在匹配'/disabled/'的行前面插入一行
sed '$ithis is the end of the file' sed_test.txt 在最后一行前面插入一行

2.更改文件中匹配的行: c

sed '1cthis is a new line' sed_test.txt 将第1行替换为:this is a new line 
sed '/disabled/cthis is a new line' sed_test.txt 将匹配‘/disabled/’的行替换为: this is a new line
sed '$cthis is the end of the file' sed_test.txt	将文件中最后一行替换为this is the end of the file

3.删除文件中匹配的行

sed '3d' sed_test.txt		删除文件中的第3行
sed '1~2d' sed.test.txt  从第一行开始,然后每隔2行删除一次,删除奇数行
sed '1,3d' sed_test.txt		删除第3到第3行
sed '1,3!d' sed_test.txt		删除1-3之外的所有行
sed '$d' sed_test.txt		删除最后一行
sed ‘/disabled/d’sed_test.txt  删除匹配‘/disabled/’的行
sed '/disabled/,$d' sed_test.txt	删除匹配了两个模式之间的所有行
sed '/disabled/,+nd' sed_test.txt		删除匹配行及后面n行
sed '/^$/d' sed_test.txt	删除空行(/^$/匹配空行)
sed '/disabled/!d' sed_test.txt   匹配‘/disabled/’行部删除,其他行全部删除
sed '1,6{/disabled/d}' 删除第1-6行中匹配‘/disabled/’的行

4.替换文件中的内容: s

sed 's/disabled/enabled/' sed_test.txt	替换文本中的disabled为enabled,只会替换每行中的第一个
sed 's/disabled/enabled/g' sed_test.txt	替换文本中所有的disabled
sed 's/disabled/enabled/2' sed_test.txt	替换每行中匹配的第二个disabled
sed -n 's/disabled/enabled/gpw 2.txt' 将文本中的disabled替换成enabled,打印,并写入到2.txt中
sed -n '2s/disabled/<enabled>/gp' sed_test.txt	只对第6行中的disabled进行替换
sed 's/..$/-->>/g' sed_test.txt	替换每行的最后两个字符为:-->>
sed 's/^#.*//g;/^$/d' sed_test.txt	替换文本中的所有以字符#开头的行,并删除替换后的所有空行
sed 's/disabled/(&)/g' sed_test.txt 将所有的disabled加上(),&:表示匹配的内容
sed -r 's/^([0-9]+(#))/number: \1--\2/g' sed_test.txt 将每行开头的数字替换成number: 数字--#的形式
		括号编号顺序为:由外向内,由左向右,且最外层括号对应的编号应该包含内层括号中的数据
sed '1,4s/$/&hahaha/' sed_test.txt	给第1-4行的结尾加上hahaha,&表示匹配的内容

5.打印文件中的行: p

sed '1p' sed_test.txt		打印第1行
sed '1,3p' sed_test.txt	打印第1-3行
sed '2~2p' sed_test.txt	打印行号为2的行,然后行号每次+2,打印行号对应的行,简言之:打印偶数行
sed '$p' sed_test.txt	打印最后一行
sed '/disabled/p' sed_test.txt 打印匹配disabled的行
sed '3,$p'	sed_test.txt	打印第3行后面所有的行
sed '/enforcing/,6p' sed_test.txt	打印匹配了‘enforcing’的行到第6行之间所有的行
sed '1,/disabled/p' sed_test.txt	打印第1行到第一个匹配了‘disabled’的行

6.打印行号

sed '$=' sed_test.txt	匹配到最后一行就先打印他的行号
sed '/disabled/=' sed_test.txt	匹配到disabled的行就先打印他的行号

五、sed的工作流程

sed的工作流程主要包括:读取,执行和显示三个过程:

读取:sed从输入流(文件,管道,标准输入流)中读取一行并存储到临时缓冲区,模式缓冲区(pattern buffer)中

执行:默认情况下,所有的sed命令都会在模式空间中按顺序执行,除非指定了行的地址,否则sed命令会在所有的行上依次执行

显示:发送修改后的内容到输出流


流、总结

1)sed在使用正则表达式的时候不能在正则表示中使用!对正则取反。

2)正则表示中不能使用!做取反操作,在正则表示中!只是一个普通的字符而已,没有其他任何意义,如果需要表示取反操作,可以在应用层使用编程逻辑实现

相关推荐

总结下SpringData JPA 的常用语法

SpringDataJPA常用有两种写法,一个是用Jpa自带方法进行CRUD,适合简单查询场景、例如查询全部数据、根据某个字段查询,根据某字段排序等等。另一种是使用注解方式,@Query、@Modi...

解决JPA在多线程中事务无法生效的问题

在使用SpringBoot2.x和JPA的过程中,如果在多线程环境下发现查询方法(如@Query或findAll)以及事务(如@Transactional)无法生效,通常是由于S...

PostgreSQL系列(一):数据类型和基本类型转换

自从厂子里出来后,数据库的主力就从Oracle变成MySQL了。有一说一哈,贵确实是有贵的道理,不是开源能比的。后面的工作里面基本上就是主MySQL,辅MongoDB、ES等NoSQL。最近想写一点跟...

基于MCP实现text2sql

目的:基于MCP实现text2sql能力参考:https://blog.csdn.net/hacker_Lees/article/details/146426392服务端#选用开源的MySQLMCP...

ORACLE 错误代码及解决办法

ORA-00001:违反唯一约束条件(.)错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。ORA-00017:请求会话以设置跟踪事件ORA-00018:超出最大会话数ORA-00...

从 SQLite 到 DuckDB:查询快 5 倍,存储减少 80%

作者丨Trace译者丨明知山策划丨李冬梅Trace从一开始就使用SQLite将所有数据存储在用户设备上。这是一个非常不错的选择——SQLite高度可靠,并且多种编程语言都提供了广泛支持...

010:通过 MCP PostgreSQL 安全访问数据

项目简介提供对PostgreSQL数据库的只读访问功能。该服务器允许大型语言模型(LLMs)检查数据库的模式结构,并执行只读查询操作。核心功能提供对PostgreSQL数据库的只读访问允许L...

发现了一个好用且免费的SQL数据库工具(DBeaver)

缘起最近Ai不是大火么,想着自己也弄一些开源的框架来捣腾一下。手上用着Mac,但Mac都没有显卡的,对于学习Ai训练模型不方便,所以最近新购入了一台4090的拯救者,打算用来好好学习一下Ai(呸,以上...

微软发布.NET 10首个预览版:JIT编译器再进化、跨平台开发更流畅

IT之家2月26日消息,微软.NET团队昨日(2月25日)发布博文,宣布推出.NET10首个预览版更新,重点改进.NETRuntime、SDK、libraries、C#、AS...

数据库管理工具Navicat Premium最新版发布啦

管理多个数据库要么需要使用多个客户端应用程序,要么找到一个可以容纳你使用的所有数据库的应用程序。其中一个工具是NavicatPremium。它不仅支持大多数主要的数据库管理系统(DBMS),而且它...

50+AI新品齐发,微软Build放大招:拥抱Agent胜算几何?

北京时间5月20日凌晨,如果你打开微软Build2025开发者大会的直播,最先吸引你的可能不是一场原本属于AI和开发者的技术盛会,而是开场不久后的尴尬一幕:一边是几位微软员工在台下大...

揭秘:一条SQL语句的执行过程是怎么样的?

数据库系统能够接受SQL语句,并返回数据查询的结果,或者对数据库中的数据进行修改,可以说几乎每个程序员都使用过它。而MySQL又是目前使用最广泛的数据库。所以,解析一下MySQL编译并执行...

各家sql工具,都闹过哪些乐子?

相信这些sql工具,大家都不陌生吧,它们在业内绝对算得上第一梯队的产品了,但是你知道,他们都闹过什么乐子吗?首先登场的是Navicat,这款强大的数据库管理工具,曾经让一位程序员朋友“火”了一把。Na...

详解PG数据库管理工具--pgadmin工具、安装部署及相关功能

概述今天主要介绍一下PG数据库管理工具--pgadmin,一起来看看吧~一、介绍pgAdmin4是一款为PostgreSQL设计的可靠和全面的数据库设计和管理软件,它允许连接到特定的数据库,创建表和...

Enpass for Mac(跨平台密码管理软件)

还在寻找密码管理软件吗?密码管理软件有很多,但是综合素质相当优秀且完全免费的密码管理软件却并不常见,EnpassMac版是一款免费跨平台密码管理软件,可以通过这款软件高效安全的保护密码文件,而且可以...