sed、awk脚本编辑器

一、sed

1、sed执行原理

sed编辑器读取数据流时,它会基于换行符的位置将数据分成行。sed编 辑器根据定义好的脚本命令一次处理一行数据,然后移到下一行重复这个过程。

N:将下一行数据加载创建一个多行组来执行

D:删除多行组中的一行

P:打印某行

2、next命令

删除:

sed '/^$/d' data1.txt #--单行删除空行

sed 'N ; /System/d' data4.txt #--多行删除
替换:

sed 's/sys/aaa/' data4.txt #--替换sys为aaa,/可以用任意字符表示只需满足s的格式

sed '1,10 s/sys/aaa/' data4.txt #--替换1到10行的数据
删除:

sed 'd' data4.txt #--全部删除

sed '2,10d' data4.txt #--删除2到4行

sed '/2/,/3/d' data4.txt #--从第一个位置开始删除,第二个位置关闭
插入;

sed '1i aaa' data4.txt #--上一行插入aaa

二、awk

1、原理:逐行读取文本,默认以空格或tab键为分隔符分隔,将分隔所得的各个字段保存到内建变量中,并按模式或者条件执行编辑命令。

sed命令常用于一整行的处理,而awk比较倾向于将一行分成多个"字段"然后再进行处理。awk信息的读入也是逐行读取的,执行结果可以通过print的功能将字段数据打印显示。在使用awk命令的过程中,可以使用逻辑操作符"&&"表示"与"、"||"表示"或"、"!"表示"非";还可以进行简单的数学运算,如+、-、*、/、%、^分别表示加、减、乘、除、取余和乘方。

内建变量:

FS:列分割符。指定每行文本的字段分隔符,默认为空格或制表位。与"-F"作用相同

NF:当前处理的行的字段个数

NR:当前处理的行的行号(序数)

$0:当前处理的行的整行内容

$n:当前处理行的第n个字段

FILENAME:被处理的文件名

RS:行分隔符。awk从文件上读取资料时,将根据RS的定义把资料切割成许多条记录,而awk一次仅读入一条记录,以进行处理。预设值是'\n'

按行输出:

awk '{print}' testfile #输出所有内容

awk 'NR==1,NR==3{print}' testfile #输出第 1~3 行

awk 'NR==1||NR==3{print}' testfile #输出第1行、第3行内容
按字段输出:

awk -F ":" '{print $3}' /etc/passwd #输出每行中的第3个字段

awk -F ":" '{print 1,3}' /etc/passwd #输出每行中的第1、3个字段

相关推荐
倔强的胖蚂蚁12 小时前
AI 人工智能配置管理 Nginx
运维·nginx·云原生
上海云盾安全满满12 小时前
服务器如果做好日常维护,有什么作用
运维·服务器
正在走向自律12 小时前
企业级数据库存储运维实战:表空间自动创建与存储架构深度优化
运维·数据库·架构·表空间
csdn_aspnet12 小时前
.Net 解决 Web API 中的“服务器响应状态码为 405(方法不允许)”错误
服务器·.net·webapi
念风12 小时前
[Linux学习笔记]Uboot-DM的分析过程
linux
想唱rap12 小时前
计算机网络基础
linux·计算机网络·mysql·ubuntu·bash
饼瑶12 小时前
Isaac Sim 5.1.0 部署指南(实验室服务器)
服务器·仿真·具身智能
Agent产品评测局12 小时前
图片生成智能体哪家好?2026年企业级视觉创作与自动化选型全景横评
运维·人工智能·ai·自动化
fetasty13 小时前
chroot的Linux服务配置-当云服务器真正用起来
android·linux·服务器
猫头虎-人工智能13 小时前
ToDesk ToClaw AI自动化实测:零门槛玩转日常自动化,告别折腾与硬件损耗
运维·人工智能·架构·开源·自动化·aigc·ai编程