sed 命令
sed
可依照脚本的指令来处理、编辑文本文件,主要用来自动编辑一个或多个文件、简化对文件的反复操作、编写转换程序等。
语法:sed [-e\<script>][-f<script文件>][目标文件]
说明:
-e<script>或–expression=<script> 以选项中指定的script来处理输入的文本文件。
-f<script文件>或–file=<script文件> 以选项中指定的script文件来处理输入的文本文件。
动作说明:
a | 新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~ |
c | 取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行! |
d | 删除,因为是删除啊,所以 d 后面通常不接任何东西 |
i | 插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行) |
p | 打印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行~ |
s | 取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g 就是啦! |
只打印第二行,不打印其他的行
sed -n '1,4'p file.txt
打印从第一行到第四行的记录
sed -n '1,4'p file.txt
把第一行和第二行全部删除
# 只针对该命令的结果,不会作用于原文件
sed '1,2'd file.txt
sort 命令
sort命令,顾名思义是排序的作用,以一行内容为一个整体进行排序。
语法:cat [选项]… [文件]…
将file.txt文件的内容升序显示
cat file.txt | sort
倒叙排序
sort -f file.txt
uniq 命令
uniq
用于重复数据处理,使用前先sort排序(因为在 uniq 中定义的重复是指相邻的两行数据完全一样,排序以后相同的内容会被排到一起)。
语法:uniq [选项]... [文件]
打印重复行出现的次数(紧挨着的)
uniq -c file.txt
只打印重复的行(出现两次及以上的行)
uniq -d file.txt
打印出文件内的唯一值
uniq file.txt
split 命令
split
分裂、分割的意思,起作用是把一个大文件按行切割成小文件。
语法:split [选项]... [目标文件 [前缀]]
把 file.txt 按每20行分割成一个文件,每个文件都是以spt开头的
split -20 file.txt spt
默认是以 x
开头,split命令在某些场景还是很有用的。
今天的内容就分享到这里了,大家晚安!
系列传送门如下:
Shell脚本基础从头开始(一)── 几个linux实操技巧
Shell脚本基础从头开始(二)── 输出重定向
Shell脚本基础从头开始(三)── linux的权限管理
Shell脚本基础从头开始(四)── 第一个shell脚本
Shell脚本基础从头开始(五)── shell的输入输出
Shell脚本基础从头开始(六) ── shell条件测试
Shell脚本基础从头开始(七)── shell的流程控制
Shell脚本基础从头开始(八)── shell的循环语句
Shell脚本基础从头开始(九)── shell的循环语句控制
Shell脚本基础从头开始(十)── shell的文本过滤
Shell脚本基础从头开始(十二)── 制作一个字符菜单
Shell脚本基础从头开始(完结篇)── 利用shell编写监控脚本以及shell操作数据库