https://www.runoob.com/linux/linux-comm-awk.html
可以根据文件指定分隔符,像处理表格一样处理文本或序列。通常来处理字段,并基于字段进行过滤,或进行模式匹配。
语法
常用的内建变量
NF :记录的字段数
NR :记录的行号
OFS :输出字段分隔符,默认值与输入字段分隔符一致。
ORS :输出记录分隔符(默认值是一个换行符)
$n :当前记录的第n个字段,字段间由FS分隔
$0 :完整的输入记录
ARGV :包含命令行参数的数组
ARGC :命令行参数的数目
基本用法
awk 脚本
关于 awk 脚本,我们需要注意两个关键词 BEGIN 和 END。
BEGIN{ 这里面放的是执行前的语句 }
END {这里面放的是处理完所有的行后要执行的语句 }
{这里面放的是处理每一行时要执行的语句
以上的应用案例基本包括了常用的awk 的常用用法,更复杂的文本处理则可以通过awk 脚本完成。
https://www.runoob.com/linux/linux-comm-sed.html
与awk 相比,sed在处理文本的行具有更好的效率。
基本语法
参数说明
sed 文件处理命令
包括增加、删除、打印、替换行的内容
应用案例
以上的案例表明,sed 的一些 *** 作可以放在行的末尾,或者放在模式匹配的末尾,或者在大括号内以分号分隔,或者通过-e 命令,实现多点编辑。
https://www.runoob.com/linux/linux-comm-grep.html
grep 查找文件里符合条件的字符串。
语法
应用案例
grep 除了可以查找单个文件中匹配的模式,也可以在目录中包含特定字符的文件查找匹配模式的行。
sed编辑器是一行一行的处理文件,正在处理的内容存放在模式空间(缓冲区)中,处理完毕后按照选项的规定进行输出或文件的修改。
sed主要用来自动编辑一个或多个文件;简化文件的反复 *** 作,用于非交互编译文件。
可以使用一个简单的数字,或是一个行号范围
注意:p的动作是:打印匹配行。
1. 原始文件:
2. sed的默认动作
(1)sed的默认动作是打印文件中的所有行。
3. 打印特定行
(1)因为sed命令默认打印文件中所有行。所以第三行会被打印两遍。那如何只打印第三行呢?使用【-n】命令,只打印匹配的行。
(2)使用【-n】命令,只打印匹配到的行
(3)打印[n,m]行
(4)打印包含模式的行
(5)打印包含模式和指定行号之间的行
(6)包含模式和包含模式之间的行
(7) {}执行多个命令(command),使用;隔开。=是显示文件行的行号。p是打印匹配行
(8)!取反 *** 作
(9)q命令:第一个模式匹配完成后退出或立即退出,使用该命令打印前5行
(1)使用[]进行正则匹配
(2)其他的正则表达式
(1)打印出以#开头的行,然后用!进行反选,则表示过滤掉以#开头的行,不会过滤掉空格。
(2)匹配以#开头的行,进行取反,则打印出非#开头的行,然后其结果在对空格开头的行进行取反。即 过滤掉以#开头的行和以空格开头的行。 {}表示在定位行执行的命令组。
(3)sed支持对单个文件实现不同的 *** 作,每个 *** 作用-e参数。定位到执行的行后,使用d命令,直接删除匹配到的行。
需要注意的是,对源文件的添加要使用【-i】参数。
s:使用替换模式替换相应模式
(1)在匹配行前面替换字符,使用【s】命令。
(2)在所有行开头替换元素【s】
(3)在所有行的末尾替换元素
(4)指定行,进行替换 *** 作
(5)【&】符号代表的是匹配到的字符。在匹配到字符后,可以使用&代替。
(6)在匹配到行前面添加一行,使用【i】的命令
(7)在匹配行的后面添加一行,使用【a】命令
(8)当添加多行时,使用\n来转义
(9)@代表的是【地址定界符】,一般由三个组成,定界符可以是/,$,#等特殊字符,此命令表示,匹配特定字符的行进行替换。
(10)使用命令【g】修改全文中出现的匹配字符。
(11)若后面接数字之后在接g,表示匹配的行中,第几次出现。就替换,2g表示替换行中第二次出现。
(1)删除以非#号开头的行,即显示以#号开头的行。
(2)删除第一行
(3)删除最后一行
(4)删除指定的行区间
(5)删除包含特定单词的行
本文参考:
sed命令详解
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)