Linux命令技巧: 使用SED截取文件内容 (linux sed截取)
在Linux环境中,SED(Stream Editor)是一款非常强大的文本处理工具,它可以在命令行下处理文本文件,支持查找、替换、插入、删除等多种操作,是Linux系统上的经典工具之一。本文将介绍如何使用SED来截取文件内容,帮助你更加高效地处理文件。
一、什么是SED?
SED是一款流式文本编辑器,它能够从标准输入或文本文件中读取数据,并将处理后的结果输出到标准输出或文件中。SED将文本文件视为一系列由行组成的数据流,它可以对这些行进行操作,例如查找、替换、删除等。
在Linux系统中,我们可以使用SED命令来进行文本处理。SED语法结构如下:
sed [选项] ‘[动作]’ 文件
其中,选项包括:
– -n:仅显示命令执行结果而不输出被处理的文本到标准输出。
– -i:修改文件内容,将处理后的结果直接替换到文件中。
– -e:允许对文件应用多个sed命令。
– -r:支持正则表达式。
– -f:从指定文件读入sed命令。
动作包括:
– 查找操作:
-n:只显示匹配到的行。
-p:与-n一起使用,匹配到的行不输出,动作结束后输出所有的解析过的行。
-P:支持Perl正则表达式。
-b:在二进制模式下处理数据。
– 操作指令:
1、替换操作:s/old/new/[n],其中n表示替换第N个匹配的字符串。
2、删除操作:d,删除匹配的行。
3、添加操作:a,添加一行到匹配行的下一行。
4、插入操作:i,插入一行到匹配行的上一行。
5、打印操作:p,打印匹配的行。
6、退出操作:q,退出SED程序。
二、如何使用SED截取文件内容?
1.使用“sed -n ‘3p’ test.txt”命令,截取文件test.txt中的第三行内容并输出。其中,“-n”表示只显示匹配到的行,“3p”表示匹配到第三行并输出,输出结果如下:
“`
【test.txt】
1: one
2: two
3: three
4: four
5: five
“`
输出结果:
“`
3: three
“`
2.使用“sed -n ‘2,4p’ test.txt”命令,截取文件test.txt中的第二行到第四行内容并输出。其中,“2,4p”表示匹配到第二行到第四行并输出,输出结果如下:
“`
【test.txt】
1: one
2: two
3: three
4: four
5: five
“`
输出结果:
“`
2: two
3: three
4: four
“`
3.使用“sed -n ‘/two/,/four/p’ test.txt”命令,截取文件test.txt中从包含“two”到包含“four”行的内容,并输出。其中,“/two/,/four/”表示匹配到包含“two”到包含“four”的行并输出,输出结果如下:
“`
【test.txt】
1: one
2: two
3: three
4: four
5: five
“`
输出结果:
“`
2: two
3: three
4: four
“`
4.使用“sed -n ‘/two/,4p’ test.txt”命令,截取文件test.txt中从包含“two”行到第四行的内容,并输出。其中,“/two/,4”表示匹配到包含“two”行到第四行并输出,输出结果如下:
“`
【test.txt】
1: one
2: two
3: three
4: four
5: five
“`
输出结果:
“`
2: two
3: three
4: four
“`
5.使用“sed -n ‘/two/,+2p’ test.txt”命令,截取文件test.txt中从包含“two”行开始,之后的两行内容,并输出。其中,“/two/,+2”表示匹配到包含“two”行开始的两行并输出,输出结果如下:
“`
【test.txt】
1: one
2: two
3: three
4: four
5: five
“`
输出结果:
“`
2: two
3: three
“`
6.使用“sed -n ‘1!p’ test.txt”命令,截取文件test.txt中除之一行之外的全部内容,并输出。其中,“1!p”表示匹配到除之一行之外的所有行并输出,输出结果如下:
“`
【test.txt】
1: one
2: two
3: three
4: four
5: five
“`
输出结果:
“`
2: two
3: three
4: four
5: five
“`
三、常见的问题解决方法
1.如何将SED操作结果输出到文件?
可以使用“sed -n ‘3p’ test.txt > output.txt”命令,将结果保存到output.txt文件中。
2.如何在SED中使用正则表达式?
可以使用“-r”或“-E”选项启用正则表达式,例如“sed -n ‘/[a-zA-Z]*[0-9]*/p’ test.txt”命令可以匹配文件test.txt中所有包含字母和数字的行。
3.如何处理包含特殊字符的文件?
可以使用“-e”的选项,将多个操作指令串联起来,例如“sed -e ‘s/old/new/g’ -e ‘s/*/#/g’ test.txt”命令将文件test.txt中所有“old”替换为“new”,并将所有的“*”替换为“#”。
四、
使用SED截取文件内容是一项非常有用的技能,可以帮助我们更加高效地处理文本文件。本文介绍了SED的基本语法结构和常见的应用场景,希望能够帮助读者更好地理解SED的使用方法,进一步提高Linux命令行的技能水平。
相关问题拓展阅读:
- 关于Linux里的sed命令。
- linux下批量文件内容提取
关于Linux里的sed命令。
Sed
is
a
nondestructive
editor.
It
will
display
the
edits
you
make
on
your
screen,
but
it
will
not
change
the
file
you
are
editing.
To
really
reflect
the
edits
in
the
file,
you
must
redirect
the
output
to
another
file,
and
then
rename
the
orginal
file
sed的特点就是非破坏(nondestructive),流水行(streamlined),非交互(noninteractive)的编辑器。
非破坏就是指不会修改原文件,它会将修改的结果标准输出到屏幕上,你如果想保存,需要使用IO重定向的方式保存:
如:
sed
‘s/home/home1’
1.txt
>2.txt
这样做的原因是,如果你修改了原文件的话,你没法使用word,vim,txt的undo功能撤销修改,恢复原来的文件。所以,sed会将修改之后的文件输出到屏幕,你看到修改满意的话,再重定向到其他文件。就完成了修改。明白否?
-e是启用多行命令
上述两条编辑命令都是一行命令,所以看不出效果。
linux下批量文件内容提取
grep ingcn -rl /assign-path | xargs sed -i ‘s/ingcn/.ingcn/g’
或
sed -i ‘s/ingcn/.ingcn/g’ `grep ingcn -rl /assign-path`
还有一种比较复杂的写法:
grep ingcn * -R | awk -F: ‘{print $1}’ | sort | uniq | xargs sed -i ‘s/ingcn/.ingcn/g’
其中命令awk用于分割字符串、uniq对结果进行除重。
、网络上现成的资料
格式: sed -i s/查找字段/替换字段/g `grep 查找字段 -rl 路径`
linux sed 批量替换多个文件中的字符串
sed -i s/oldstring/newstring/g `grep oldstring -rl yourdir`
例如:替换/home下所有文件中的.111cn.为111cn.
sed -i s/.111cn./111cn./g `grep .111cn. -rl /home`
exp:sed -i s/shabi/$/g `grep shabi -rl ./`
2、自己额外附加
2.1 将文件1.txt内的文字garden替换成mirGarden
# sed -i s/garden/mirGarden/g
1.txt sed -i 很简单
2.2 将当前目录下的所有文件内的garden替换成mirGarden
## sed -i s/garden/mirGarden/g `ls` 其实也就是ls出多个文件名而已
关于linux sed截取的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。