说起Linux *** 作系统中的 grep 命令,或许没有人会不知道。在我看来, grep 命令是Linux *** 作系统上最强大的工具之一,正如你无时无刻不在使用它。无论是从文件中找到匹配的行,又或者是从终端输出中获取指定信息,都离不开对 grep 的使用。
了解一个工具的使用,还是先看这个工具的man手册会告诉我们什么。
手册中提到, grep 工具还有两个孪生兄弟,分别是 egrep 和 fgrep 。其中, egrep 相当于 grep -E 的用法,使用的是扩展形式的正则表达式; fgrep 相当于 grep -F 的用法,根据固定模式进行内容匹配。
对于任何的Linux *** 作系统,你可以很轻松的找到 /etc/passwd 文件,以下的多数演示将会以该文件进行演示。以下为用户的部分信息
grep 命令的格式相对比较简单。完整的命令格式如 grep [OPTIONS] PATTERN [FILE...] ,其中 [OPTIONS] 选项提供了众多的参数,如下
如果需要找到包含 root 用户和 adm 用户的行,可以通过 grep -E "root|adm" /etc/passwd 来查找所有满足的行
了解 grep 的常用参数可以在工作中解决绝大部份的问题,但在一些情况下,需要对过滤出的内容按照某种规则进行精确匹配,还需要配合正则使用。以下介绍了几种常用的正则语法
Linux三剑客awk命令篇二:命令 *** 作符
关于awk的原理等基本知识请参考上篇:
Linux三剑客awk命令篇一:原理及基本命令
补充
1、语法格式:
(1) Awk完整语法
awk 'BEGIN{commands} pattern{commands}END{commands} ' file
BEGIN{commands}:处理数据前执行的命令。
END{commands}:处理完数据后执行的命令。
这两个命令可以省略。见(2)
(2) Awk基本语法
awk -F '分割符' '/模式/{动作} ' file
这里的 '/模式/{动作} ' 类似于sed的命令格式。
模式:
(1) 正则表达式(注意格式: /正则表达式/ )
(2) 条件表达式(例如:><等等)
总结:
这里的模式通俗来讲是 用来找谁, 而动作表示是 干啥。
2、 awk的命令 *** 作符
(1) 正则表达式与bash一致
(2) + - * / % ++ --
(3) &&|| !
(4) ><>= <= != == ~ !~
~:表示匹配后面的模式,用于字段,见 案例1 。
其余的都比较常见就不举例了。
3、案例
案例1:
~使用案例
awk -F : '$3 ~ /\<...\>/{print $1,$3}' /etc/passwd
解释:
模式:\<...\>
\<\>表示定界符,只匹配3个字符。
$3 ~:表示$3这个字段必须符合后面模式(\<...\>)的要求。
见如下输出结果,$3都是3个字符。
案例2:
% || ==使用案例
seq 100 | awk '$1 % 7 == 0 || $1 ~ /^99/{print $1}'
输出结果的要求:
整除7或者以99开头
案例3:
++使用
awk 'BEGIN{num=0}{num++}END{print num}' /etc/passwd
简单解释:
BEGIN{num=0}:定义一个变量num
{num++}:这里没有模式,只有动作。
即每匹配到文件/etc/passwd的一行就执行num++
END{print num}:文件遍历结束,打印num的值,即文件的行数。
这里我们使用wc -l验证也是没问题的。
cat /etc/passwd | wc -l
上面3个案例简单的使用了awk的命令 *** 作符。
虽然只是用到了几个简单的,但是其他同理,大家可以执行 *** 作。
下一篇:
Linux三剑客awk命令篇二之内部变量
欢迎大家给予宝贵的意见或者建议。
欢迎大家补充或者共享一些其他的方法。
感谢支持。
三剑客各有所长,和锅锅一一搞起就是了!
使用示例:
使用示例:
使用示例:
sed [选项] s/[pattern]/[replace]/[flags]
[选项]常用的几个参数:
[pattern]
含义:待匹配的需要替换的内容。
[replace]
常见的特殊含义字符:
[flags]
常见的可选参数:
多个sed命令依次执行,用分号分割或加选项 -e,
使用示例:
把 test.html 文件中的第二个 <body> 替换为 </body>。
分析实际就是把第二个 body 替换为 /body,命令如下。
把 test.html 文件中的第二个 <body> 替换为 </body>。
分析实际就是把第二个 body 替换为 /body,命令如下。
编写执行脚本的步骤如下:
touch sed.sh
sed.sh 中写入脚本内容:
对sed.sh 脚本赋予可执行权限
chmod ug+x sed.sh
执行sed.sh 脚本,对文件进行处理
sed -i -f sed.sh test.html
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)