sed 命令详解

简介:
sed 命令详解

概述

sed是stream editor的简称,也就是流编辑器。它一次处理一行内容,处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”pattern space,接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存储输出。

使用语法

sed命令的使用规则是这样的:

 
 
  1. sed [option] 'command' input_file

其中option是可选的,常用的option有如下几种:

  • -n 使用安静silent模式(想不通为什么不是-s)。在一般sed的用法中,所有来自stdin的内容一般都会被列出到屏幕上。但如果加上-n参数后,则只有经过sed特殊处理的那一行(或者动作)才会被列出来;
  • -e 直接在指令列模式上进行 sed 的动作编辑;
  • -f 直接将 sed 的动作写在一个文件内, -f filename 则可以执行filename内的sed命令;
  • -r 让sed命令支持扩展的正则表达式(默认是基础正则表达式);
  • -i 直接修改读取的文件内容,而不是由屏幕输出。

常用的命令有以下几种:

  • a \:追加行append, a \的后面跟上字符串s(多行字符串可以用\n分隔),则会在当前选择的行的后面都加上字符串s;

  • c \:取代/替换行change,c \后面跟上字符串s(多行字符串可以用\n分隔),则会将当前选中的行替换成字符串s;
  • i \:插入行insert,i \后面跟上字符串s(多行字符串可以用\n分隔),则会在当前选中的行的前面都插入字符串s;
  • d:删除行delete,该命令会将当前选中的行删除;
  • p:打印print,该命令会打印当前选择的行到屏幕上;
  • s:替换字符串subs,通常s命令的用法是这样的:1,2s/old/new/g,将old字符串替换成new字符串

命令示例

假设有一个本地文件test.txt,文件内容如下:

 
 
  1. [qifuguang@winwill~]$ cat test.txt
  2. this is first line
  3. this is second line
  4. this is third line
  5. this is fourth line
  6. this fifth line
  7. happy everyday
  8. end

本节将使用该文件详细演示每一个命令的用法。

a命令(追加行)

例一

 
 
  1. [qifuguang@winwill~]$ sed '1a \add one' test.txt
  2. this is first line
  3. add one
  4. this is second line
  5. this is third line
  6. this is fourth line
  7. this is fifth line
  8. happy everyday
  9. end

本例命令部分中的1表示第一行,同样的第二行写成2,第一行到第三行写成1,3,用$表示最后一行,比如2,$表示第二行到最后一行中间所有的行(包含第二行和最后一行)。

本例的作用是在第一行之后增加字符串”add one”,从输出可以看到具体效果。

例二

 
 
  1. [qifuguang@winwill~]$ sed '1,$a \add one' test.txt
  2. this is first line
  3. add one
  4. this is second line
  5. add one
  6. this is third line
  7. add one
  8. this is fourth line
  9. add one
  10. this is fifth line
  11. add one
  12. happy everyday
  13. add one
  14. end
  15. add one

本例表示在第一行和最后一行所有的行后面都加上”add one”字符串,从输出可以看到效果。

例三

 
 
  1. [qifuguang@winwill~]$ sed '/first/a \add one' test.txt
  2. this is first line
  3. add one
  4. this is second line
  5. this is third line
  6. this is fourth line
  7. this is fifth line
  8. happy everyday
  9. end

本例表示在包含”first”字符串的行的后面加上字符串”add one”,从输出可以看到第一行包含first,所以第一行之后增加了”add one”

例四

 
 
  1. [qifuguang@winwill~]$ sed '/^ha.*day$/a \add one' test.txt
  2. this is first line
  3. this is second line
  4. this is third line
  5. this is fourth line
  6. this is fifth line
  7. happy everyday
  8. add one
  9. end

本例使用正则表达式匹配行,^ha.*day$表示以ha开头,以day结尾的行,则可以匹配到文件的”happy everyday”这样,所以在该行后面增加了”add one”字符串。

i命令(插入行)

i命令使用方法和a命令一样的,只不过是在匹配的行的前面插入字符串,所以直接将上面a命令的示例的a替换成i即可,在此就不啰嗦了。

c命令(替换行)

例五

 
 
  1. [qifuguang@winwill~]$ sed '$c \add one' test.txt
  2. this is first line
  3. this is second line
  4. this is third line
  5. this is fourth line
  6. this is fifth line
  7. happy everyday
  8. add one

本例表示将最后一行替换成字符串”add one”,从输出可以看到效果。

例六

 
 
  1. [qifuguang@winwill~]$ sed '4,$c \add one' test.txt
  2. this is first line
  3. this is second line
  4. this is third line
  5. add one

本例将第四行到最后一行的内容替换成字符串”add one”。

例七

 
 
  1. [qifuguang@winwill~]$ sed '/^ha.*day$/c \replace line' test.txt
  2. this is first line
  3. this is second line
  4. this is third line
  5. this is fourth line
  6. this is fifth line
  7. replace line
  8. end

本例将以ha开头,以day结尾的行替换成”replace line”。

d命令(删除行)

例八

 
 
  1. [qifuguang@winwill~]$ sed '/^ha.*day$/d' test.txt
  2. this is first line
  3. this is second line
  4. this is third line
  5. this is fourth line
  6. this is fifth line
  7. end

本例删除以ha开头,以day结尾的行。

例九

 
 
  1. [qifuguang@winwill~]$ sed '4,$d' test.txt
  2. this is first line
  3. this is second line
  4. this is third line

本例删除第四行到最后一行中的内容。

p命令(打印行)

例十

 
 
  1. [qifuguang@winwill~]$ sed -n '4,$p' test.txt
  2. this is fourth line
  3. this is fifth line
  4. happy everyday
  5. end

本例在屏幕上打印第四行到最后一行的内容,p命令一般和-n选项一起使用。

例十一

 
 
  1. [qifuguang@winwill~]$ sed -n '/^ha.*day$/p' test.txt
  2. happy everyday

本例打印以ha开始,以day结尾的行。

s命令(替换字符串)

实际运用中s命令式最常使用到的。

例十二

 
 
  1. [qifuguang@winwill~]$ sed 's/line/text/g' test.txt
  2. this is first text
  3. this is second text
  4. this is third text
  5. this is fourth text
  6. this is fifth text
  7. happy everyday
  8. end

本例将文件中的所有line替换成text,最后的g是global的意思,也就是全局替换,如果不加g,则只会替换本行的第一个line。

例十三

 
 
  1. [qifuguang@winwill~]$ sed '/^ha.*day$/s/happy/very happy/g' test.txt
  2. this is first line
  3. this is second line
  4. this is third line
  5. this is fourth line
  6. this is fifth line
  7. very happy everyday
  8. end

本例首先匹配以ha开始,以day结尾的行,本例中匹配到的行是”happy everyday”这样,然后再将该行中的happy替换成very happy。

例十四

 
 
  1. [qifuguang@winwill~]$ sed 's/\(.*\)line$/\1/g' test.txt
  2. this is first
  3. this is second
  4. this is third
  5. this is fourth
  6. this is fifth
  7. happy everyday
  8. end

这个例子有点复杂,先分解一下。首先s命令的模式是s/old/new/g这样的,所以本例的old部分即\(.*\)line$,sed命令中使用\(\)包裹的内容表示正则表达式的第n部分,序号从1开始计算,本例中只有一个\(\)所以\(.*\)表示正则表达式的第一部分,这部分匹配任意字符串,所以\(.*\)line$匹配的就是以line结尾的任何行。然后将匹配到的行替换成正则表达式的第一部分(本例中相当于删除line部分),使用\1表示匹配到的第一部分,同样\2表示第二部分,\3表示第三部分,可以依次这样引用。比如下面的例子:

 
 
  1. [qifuguang@winwill~]$ sed 's/\(.*\)is\(.*\)line/\1\2/g' test.txt
  2. this first
  3. this second
  4. this third
  5. this fourth
  6. this fifth
  7. happy everyday
  8. end

正则表达式中is两边的部分可以用\1\2表示,该例子的作用其实就是删除中间部分的is。

本文来自云栖社区合作伙伴“Linux中国”,原文发表于2013-04-02.

相关文章
|
8月前
|
监控 JavaScript 前端开发
ry-vue-flowable-xg:震撼来袭!这款基于 Vue 和 Flowable 的企业级工程项目管理项目,你绝不能错过
基于 Vue 和 Flowable 的企业级工程项目管理平台,免费开源且高度定制化。它覆盖投标管理、进度控制、财务核算等全流程需求,提供流程设计、部署、监控和任务管理等功能,适用于企业办公、生产制造、金融服务等多个场景,助力企业提升效率与竞争力。
464 12
|
7月前
|
域名解析 人工智能 API
使用阿里云服务器搭建自己的DeepSeek个人站点,3分钟尝鲜教程!
通过阿里云服务器,您可以0成本部署专属的DeepSeek网站。学生用户可领取300元代金券,实现免费部署;普通用户则可以选择99元/年的服务器方案。使用阿里云计算巢“DeepSeek个人站点-快速部署”服务,最快5分钟完成部署,无需编写代码。该服务集成了百炼API和Open WebUI,支持多种AI模型(如DeepSeek、Qwen-max、Llama等),并提供稳定、高性价比的个人专属AI网站体验。详情及教程请参考官方页面。
1240 1
|
12月前
|
SQL 存储 监控
串口调试助手连接SQL数据库的技巧与方法
串口调试助手是电子工程师和软件开发人员常用的工具,它能够帮助用户进行串口通信的调试和数据分析
|
缓存 前端开发 Java
在Java项目中实现跨域资源共享(CORS)
在Java项目中实现跨域资源共享(CORS)
|
C语言 Perl
西门子S7-1200编程实例,电动机起保停控制梯形图如何编写?
本篇我们通过一个电动机起保停控制的实例,介绍S7-1200的使用方法,按下瞬时启动按钮I0.6,电动机Q0.0启动,按下瞬时停止按钮I0.7,电动机Q0.0停止。
西门子S7-1200编程实例,电动机起保停控制梯形图如何编写?
|
存储 安全 数据管理
新一代数据库技术:融合区块链的分布式存储系统
传统数据库技术在面对日益增长的数据量和复杂的数据管理需求时显现出局限性。本文介绍了一种新一代数据库技术:融合区块链的分布式存储系统。通过将区块链技术与传统数据库相结合,实现了数据的分布式存储、安全性和透明度,以及去中心化的特性。这一技术的应用将极大地推动数据库系统的发展,为数据管理带来全新的解决方案。
|
存储 Kubernetes 调度
关于Pod的基础知识概览
【6月更文挑战第19天】Pod是Kubernetes的基本执行单元,是最小部署和管理的粒度,包含一个或多个共享网络和存储的容器,常比喻为豆荚中的豆子。Pod中的容器共享IP和端口,便于协作,支持Docker等容器运行时。
|
存储 数据库 时序数据库
InfluxDB是一个开源的时间序列数据库
InfluxDB是一个开源的时间序列数据库
307 2
|
存储 编译器 C语言
【C/C++ POD 类型】深度解析C++中的POD类型:从理论基础到项目实践
【C/C++ POD 类型】深度解析C++中的POD类型:从理论基础到项目实践
1179 0
|
消息中间件 监控 搜索推荐
基层卫生健康云综合管理平台源码(云HIS)
基层医疗云HIS作为基于云计算的B/S构架的HIS系统,为基层医疗机构提供了标准化的、信息化的、可共享的医疗信息管理系统,可有效进行医疗数据共享与交换,解决数据重复采集及信息孤岛等问题,实现对基层医疗数据的分析和挖掘,为基层卫生机构提供科学合理的业务管理服务。 可实现“云部署”,即可实现在云计算下的多种部署模式。系统采用SaaS服务模式的新驱动,功能设计充分合理,界面布局合理美观,每个用户可具有个性化工作台。
646 1