Linux三剑客——sed命令

作用

  • sed命令是一个非交互式的行文本编辑器,它能对文件内容进行编辑,默认每次处理文本文件中所匹配到一行内容到模式空间,然后用后面的命令进行操作,操作完成之后,会把模式空间里面的内容输出到屏幕上,然后把模式空间中的内容删除,同时把下一行所匹配到的内容读入模式空间内,依次循环,直到读取完整个文件。
  • sed 命令处理的是缓冲区中的内容,其实这里的缓冲区,就是模式空间

语法

sed语法支持两种格式,分别是

  • sed [options] ‘address command’ file
  • sed [options] -f [scripefile] file

对以上的几个英语字符进行说明:

  • options为选项,其中sed支持的选项会在下面的选项小结说明
  • address : 相当于匹配的条件,会在地址中进行说明
  • command为命令,相当于一个参数,放在地址后面,具体见下面的命令小节说明
  • file :为文本文件

需要说明的是,使用时address和command会挨在一起,中间没有空格,上面语法中间加空格是为了说明这是两个部分

以下为sed命令的工作流程图
请添加图片描述

选项

这里的选项就是指sed之后的options,常见的选项具体如下:

-e ,--expression=script 
以选项中指定的script参数来处理文本文件,可以指定多个命令

-f file,--files=script
以文件中的指定的参数来处理文本文件
​
-n ,--quiet ,--slient
取消默认输出,sed默认会输出所有文本内容,使用-n参数后只显示处理过的行
​
-r ,--regexp-extended
支持扩展正则表达式
​
-i,--in-place[=SUFFIX]
直接修改文件内容

地址

这里的地址就是语法格式中的address部分,是在单引号里的前一部分 。

替换标记说明 linenumber指定特定行号startline,endline指定起始行号和结束行号linenumber,+nn为数字,表示从指定行号向后n行/pattern/已正则表达式表示的匹配模式/pattern1, /pattern2/从模式匹配1到模式匹配2pattern/,x在给定行号上查询包含模式的行x,/pattern/通过行号和模式查询匹配的行x,y!查询不包含指定行号x和y的行

命令

这里的指令就是command,这个一般放在单引号内,同时和要处理的字符放在一起,只是command放在字符的前面。

a 追加,向匹配行后面插入内容 
i 插入,向匹配行前插入内容
c 更改,更改匹配行的内容
d 删除,删除匹配行的内容
s 使用替换模式替换相应模式
s/patten/newstring 替换,把patten匹配到的内容换成newstring
p 打印,打印出匹配的内容,通过与-n选项配合使用
= 标号,用来将匹配的行前标号
n 读取下一行,遇到n会自动自动跳入下一行
r 将内容读入文件
{} 命令间的传递,类似于管道符|
w 将匹配内容写入文件
W 将匹配到行的第一行,保存到file中。

替换标记

  • g : 表示将匹配到的内容进行全局替换 。
  • \1 :表示前面第一个左括号所表示的内容 ,\2表示前面第二个左括号中表示的内容,依次类推
  • & : 表示前面匹配到的内容

正则匹配

正在匹配在上面已经介绍到,详情请见正则表达式介绍。具体见:35个参数13个案例,全面解析Linux三剑客之grep命令

实例

以下主要针对地址指令的实战练习

先准备数据文件aa.txt,通过cat查看aa.txt文件内容

[root@localhost test]# cat aa.txt 
总用量 28
lrwxrwxrwx.   1 root root     7 9月  10 06:12 bin -> usr/bin
dr-xr-xr-x.   6 root root  4096 9月  10 06:44 boot
drwxr-xr-x.  20 root root  3360 9月  29 05:19 dev
drwxr-xr-x.   3 root root    20 9月  14 03:08 docker_registry
drwxr-xr-x.   2 root root    41 9月  17 06:23 docker_study
drwxr-xr-x. 151 root root 12288 9月  29 05:20 etc
drwxr-xr-x.   3 root root    18 9月  10 06:57 home
lrwxrwxrwx.   1 root root     7 9月  10 06:12 lib -> usr/lib
lrwxrwxrwx.   1 root root     9 9月  10 06:12 lib64 -> usr/lib64
drwxr-xr-x.   2 root root     6 4月  11 2018 media
drwxr-xr-x.   2 root root    21 9月  19 21:51 mnt
drwxr-xr-x.   4 root root    34 9月  11 06:53 opt
dr-xr-xr-x. 307 root root     0 9月  29 05:19 proc
dr-xr-x---.   7 root root   266 9月  29 05:20 root
drwxr-xr-x.  45 root root  1320 9月  29 06:26 run
lrwxrwxrwx.   1 root root     8 9月  10 06:12 sbin -> usr/sbin
drwxr-xr-x.   2 root root     6 4月  11 2018 srv
dr-xr-xr-x.  13 root root     0 9月  29 05:19 sys
drwxr-xr-x.   3 root root    43 9月  26 19:11 test
drwxrwxrwt.  24 root root  4096 9月  29 06:38 tmp
drwxr-xr-x.  13 root root   155 9月  10 06:12 usr
drwxr-xr-x.  22 root root  4096 9月  10 06:45 var

显示文件中的第2行内容 .
请添加图片描述
删除文件中3~13行
请添加图片描述
删除匹配boot的行
请添加图片描述
删除以d开头的行
请添加图片描述
删除包含d字符的行
请添加图片描述
打印匹配以d开头到以l开头的行(多次匹配)
请添加图片描述
打印dev到第5行,其中不包含第5行
请添加图片描述
打印第2行到匹配到dev之间的行
请添加图片描述
除3~16行之间的数据,将其它数据输出
请添加图片描述
以下主要正则正则匹配的实战练习

先准备数据文件,通过cat命令查看java.conf文件

[root@localhost test]# 
[root@localhost test]# cat java.conf 
# System-wide Java configuration file  -*- sh -*-

# Location of jar files on the system
JAVA_LIBDIR=/usr/share/java

# Location of arch-specific jar files on the system
JNI_LIBDIR=/usr/lib/java

# Root of all JVM installations
JVM_ROOT=/usr/lib/jvm

# You can define a system-wide JVM root here if you're not using the
# default one.
#
# If you have a base JRE package installed
# (e.g. java-1.6.0-openjdk):
#JAVA_HOME=$JVM_ROOT/jre
#
# If you have a devel JDK package installed
# (e.g. java-1.6.0-openjdk-devel):
#JAVA_HOME=$JVM_ROOT/java

# Options to pass to the java interpreter
#JAVACMD_OPTS=

# You can disable ABRT Java Connector by setting JAVA_ABRT to "off".
# See: https://github.com/jfilak/abrt-java-connector/
#JAVA_ABRT=off
[root@localhost test]# 

过滤掉注释的行,备注:注释的行是以#开头
请添加图片描述
过滤掉所有的空行
请添加图片描述
过滤掉所有注释行和空行,此命令用到{},不清楚的可参考上面的命令
请添加图片描述
删除掉所有注释行和空行,(这里的删除并非对源文件内容进行删除)
请添加图片描述
匹配任何包含JVM的行
请添加图片描述
匹配包含JNI_LIBDIR或者JVM_ROOT的行
请添加图片描述
匹配任何包含数字的行
请添加图片描述
以下主要针对各命令的练习,如s,i,a,r,w,p等

将含有aaa字符的第一个字符a 替换成b.
请添加图片描述
将含有aaa的字符替换成bbb.
请添加图片描述
将JAVA_HOME替换成JAVA_DIR,注意,此文件包含多行JAVA_HOME
请添加图片描述
替换第二行内容中的root为test,注意是第一个匹配到的root字符。
请添加图片描述
替换第二,三行中的root为test,这次为全局替换
请添加图片描述
替换第二行到最后一行的root为test(全局替换)
请添加图片描述
在匹配See字符的行,行首添加hello
请添加图片描述
在匹配See字符的行,在See字符后添加hello
请添加图片描述
在匹配See字符的行,在See字符前添加hello
请添加图片描述
在匹配See字符的行,在行尾添加hello
请添加图片描述
在每一行的开头添加hello 。
请添加图片描述
在每一行的结尾添加hello 。
请添加图片描述
在前三行的行首添加hello 。
请添加图片描述
在匹配ddd字符的行的前面一行添加hello
请添加图片描述
在匹配ddd字符的行的后面一行添加hello
请添加图片描述
在匹配的ddd行的下一行添加多行内容。
请添加图片描述
将一个新行添加到文件的第三行。
请添加图片描述
查询boot的行是在第几行
请添加图片描述
以上所有的替换或变化都不会改变原文件的内容 。

将文件info中的ccc修改为xyz。
请添加图片描述
将文件info中匹配到tmp的行,其中包含root的字符修改为test .
请添加图片描述
在匹配kkk的行的结尾添加end字符 。
请添加图片描述
直接替换文件中第三行的内容。

请添加图片描述
将指定文件abc.txt中的内容插入到info文件的第三行
请添加图片描述
将文件aa.txt中的前两行输出到文本文件abc.txt。
请添加图片描述
将aa.txt中匹配boot的行写入到a1.txt中
请添加图片描述
读取文件a.sh中的指令进行替换xxx为hello world .
请添加图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux三剑客指的是 awk、sed 和 grep。 awk 是一种用来处理文本文件的工具,它可以根据指定的模式进行自动分割并进行数据处理。 sed 是一种流编辑器,它可以对文本文件进行替换、删除和插入操作。 grep 是一种文本搜索工具,它可以在文本文件中搜索指定的字符串。 ### 回答2: Linux三剑客,分别是awk、sed和grep,它们是Linux系统中非常重要的命令行工具,它们通常被称为文本处理工具。这些工具通常被用于筛选、搜索和处理文本文件。 grep是一种常见的文本搜索工具,可以在文件和文件夹中搜索指定的字符串或正则表达式。grep可以搜索多个文件并返回匹配行的输出。它是处理日志文件或查找匹配模式的最佳工具之一。 sed是一种流编辑器,可以按照行处理文本文件。它可以通过替换、删除和插入操作来修改文件内容。在大型文件中查找并替换模式是sed的主要作用。该工具通常在文本文件中提取有用信息是常用。 awk是一种强大的文本操作工具,可以分析大型文本文件并对其进行处理。该工具可以遍历行和列,并提供强大的文本处理工具,如计算、过滤和转换数据。awk的处理速度非常快,适用于处理大型数据文件。 Linux三剑客中awk是最强大的工具,它可以执行复杂的文本数据操作和转换,可大大简化开发和管理过程。sed主要用于简单的文本数据过滤和替换,而grep主要用于搜索文件和定位特定行。 总之,Linux三剑客在文本数据处理方面具有不可替代的重要作用。对于Linux操作系统的开发人员和管理员来说,熟练使用这些工具可以提高他们的工作效率,使他们更容易管理和操作文本文件。 ### 回答3: Linux三剑客awk sed grep是我们在日常工作中经常使用的三个命令。它们都属于文本处理工具,可以用于查找、处理、分析文本文件等。 首先,grep是最常用的文本搜索工具。grep可以用来快速查找文件中指定的字符串或正则表达式,并将包含该字符串或正则表达式的行打印出来。常用的命令有grep、egrep和fgrep。比如,我们可以使用grep命令来查找一个文件中包含指定关键字的行,可以使用egrep来支持正则表达式搜索,使用fgrep来进行快速搜索,不支持正则表达式。 其次,sed是一种流编辑器,主要用于对文本文件进行替换、删除、添加、插入等操作。sed命令可以通过管道(|)将多个命令组合起来,从而进行复杂的文本操作。sed可以快速完成对文本文件的修改操作,比如替换文件中的某些内容、删除特定的行、在文件中插入新的文本等。sed命令形式是“command", 比如"s/old/new/g",表示将old替换成new。 最后,awk是一种强大的文本处理工具,主要用于在文本文件中查找、处理以及格式化特定的字段。和grep、sed不同的是,awk更加灵活,可以在处理过程中做到数据过滤和加工,对于大数据的处理特别有用。awk命令的常用语法是"pattern {action}"。其中,pattern代表要匹配的模式,而action代表模式匹配时需要执行的动作,我们可以在其中添加处理语句来对文件进行各种处理操作,比如计算、统计、格式化等。 综上所述,Linux三剑客awk sed grep是我们在文本处理工作中不可或缺的三个工具,不同的工具可以用于处理不同的文本操作,也可以用于搭配使用,以完成更加复杂的文本处理工作。对于需要经常处理文本的人员来说,掌握这些工具是非常必要的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值