返回顶部

Linux 文本处理工具

Linux上文本处理三剑客

grep, egrep, fgrep:文本过滤工具(模式:pattern)工具;

  • grep:基本正则表达式,-E,-F
  • egrep:扩展正则表达式, -G,-F
  • fgrep:不支持正则表达式,

sed:stream editor, 流编辑器;文本编辑工具;

awk:Linux上的实现为gawk,文本报告生成器(格式化文本);

grep  Global search REgular expression and Print out the line

  • 作用:文本搜索工具,根据用户指定的“模式(过滤条件)”对目标文本逐行进行匹配检查;打印匹配到的行;
  • 模式:由正则表达式的元字符及文本字符所编写出的过滤条件;

正则表达式引擎

  • grep [OPTIONS] PATTERN [FILE...]
  • grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]

OPTIONS:

  • --color=auto:对匹配到的文本着色后高亮显示;
  • -i:ignorecase,忽略字符的大小写;
  • -o:仅显示匹配到的字符串本身;
  • -v, --invert-match:显示不能被模式匹配到的行;
  • -E:支持使用扩展的正则表达式元字符;
  • -q, --quiet, --silent:静默模式,即不输出任何信息;
  • -A #:after, 后#行
  • -B #:before,前#行
  • -C #:context,前后各#行

基本正则表达式元字符:

字符匹配:

  • . :匹配任意单个字符;
  • []:匹配指定范围内的任意单个字符;
  • [^]:匹配指定范围外的任意单个字符;
  • [:digit:]、[:lower:]、[:upper:]、[:alpha:]、[:alnum:]、[:punct:]、[:space:]

匹配次数:用在要指定其出现的次数的字符的后面,用于限制其前面字符出现的次数;默认工作于贪婪模式;

  • *:匹配其前面的字符任意次;0,1,多次;

 

  • .*:匹配任意长度的任意字符
  • \?:匹配其前面的字符0次或1次;即其前面的字符是可有可无的;
  • \+:匹配其前面的字符1次或多次;即其面的字符要出现至少1次;
  • \{m\}:匹配其前面的字符m次;
  • \{m,n\}:匹配其前面的字符至少m次,至多n次;
  • \{0,n\}:至多n次
  • \{m,\}:至少m次

位置锚定:

  • ^:行首锚定;用于模式的最左侧;
  • $:行尾锚定;用于模式的最右侧;
  • ^PATTERN$:用于PATTERN来匹配整行;
  • ^$:空白行;
  • ^[[:space:]]*$:空行或包含空白字符的行;
  • 单词:非特殊字符组成的连续字符(字符串)都称为单词;
  • \< 或 \b:词首锚定,用于单词模式的左侧;
  • \> 或 \b:词尾锚定,用于单词模式的右侧;
  • \<PATTERN\>:匹配完整单词;
练习

1、显示/etc/passwd文件中不以/bin/bash结尾的行;

 grep -v "/bin/bash$" /etc/passwd

2、找出/etc/passwd文件中的两位数或三位数;

 grep "\<[0-9]\{2,3\}\>" /etc/passwd

3、找出/etc/rc.d/rc.sysinit或/etc/grub2.cfg文件中,以至少一个空白字符开头,且后面非空白字符的行;

grep "^[[:space:]]\+[^[:space:]]" /etc/grub2.cfg

4、找出"netstat -tan"命令的结果中以'LISTEN'后跟0、1或多个空白字符结尾的行;

netstat -tan | grep "LISTEN[[:space:]]*$"

分组及引用

  • \(\):将一个或多个字符捆绑在一起,当作一个整体进行处理;
  • \(xy\)*ab

Note:分组括号中的模式匹配 到的内容会被正则表达式引擎自动记录于内部的变量中,这些变量为:

  • \1:模式从左侧起,第一个左括号以及与之匹配的右括号之间的模式所匹配到的字符;
  • \2:模式从左侧起,第二个左括号以及与之匹配的右括号之间的模式所匹配到的字符;
  • \3
  • ...

lovers.txt

He loves his lover.
He likes his lover.
She likes her liker.
She loves her liker.

~]# grep "\(l..e\).*\1" lovers.txt

后向引用:引用前面的分组括号中的模式所匹配到的字符; (在这里\1引用的是前面的匹配,所以前后匹配的内容一致

 

egrep

egrep:支持扩展的正则表达式实现类似于grep文本过滤功能;grep -E

egrep [OPTIONS] PATTERN [FILE...]

选项:

  • -i, -o, -v, -q, -A, -B, -C
  • -G:支持基本正则表达式

扩展正则表达式的元字符:

  • 字符匹配:
  • .:任意单个字符
  • []:指定范围内的任意单个字符
  • [^]:指定范围外的任意单个字符

次数匹配:

  • *:任意次,0,1或多次;
  • ?:0次或1次,其前的字符是可有可无的;
  • +:其前字符至少1次;
  • {m}:其前的字符m次;
  • {m,n}:至少m次,至多n次;
  • {0,n}
  • {m,}

位置锚定

  • ^:行首锚定;
  • $:行尾锚定;
  • \<, \b:词首锚定;
  • \>, \b:词尾锚定;

分组及引用:

  • ():分组;括号内的模式匹配到的字符会被记录于正则表达式引擎的内部变量中;
  • 后向引用:\1, \2, ...
  • 或:
  • a|b:a或者b;
  • C|cat:C或cat
  • (c|C)at:cat或Cat

练习:

1、找出/proc/meminfo文件中,所有以大写或小写S开头的行;至少有三种实现方式;

grep -i "^s" /proc/meminfo
grep "^[sS]" /proc/meminfo
grep -E "^(s|S)" /proc/meminfo


2、显示肖前系统上root、centos或user1用户的相关信息;

grep -E "^(root|centos|user1)\>" /etc/passwd

3、找出/etc/rc.d/init.d/functions文件中某单词后面跟一个小括号的行;

 grep -E -o "[_[:alnum:]]+\(\)" /etc/rc.d/init.d/functions

4、使用echo命令输出一绝对路径,使用egrep取出基名;(不是以 / 开头任意字符  )

echo /etc/sysconfig/ | grep -E -o "[^/]+/?$"


进一步:取出其路径名;类似于对其执行dirname命令的结果;


5、找出ifconfig命令结果中的1-255之间的数值;

 ifconfig | grep -E -o "\<([1-9]|[1-9][0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])\>"


7、添加用户bash, testbash, basher以及nologin(其shell为/sbin/nologin);而后找出/etc/passwd文件中用户名同shell名的行;

grep -E "^([^:]+\>).*\1$" /etc/passwd

fgrep

  • 不支持正则表达式元字符;
  • 当无需要用到元字符去编写模式时,使用fgrep必能更好;

文本查看及处理工具:wc, cut, sort, uniq, diff, patch

wc [OPTION]... [FILE]...

  • -l: lines  显示一共有多少行
  • -w:words  显示总共有多少单词数
  • -c: bytes  显示字节数
wc -l /etc/passwd

cut OPTION... [FILE]... 按照指定的字符进行切割,取出相应的字段

OPTION:

  • -d CHAR:以指定的字符为分隔符;
  • -f FIELDS:挑选出的字段;

按照  :进行切割,取出第七个字段

cut -d: /etc/passwd -f7

sort [OPTION]... [FILE]...   命令用于将文本文件内容加以排序

  • -n:基于数值大小而非字符进行排序;
  • -t CHAR:指定分隔符;
  • -k :用于排序比较的字段;
  • -r:逆序排序
  • -f:忽略字符大小写
  • -u:重复的行只保留一份; 重复行:连续且相同;

sort 命令将以默认的方式将文本文件的第一列以ASCII 码的次序排列,并将结果输出到标准输出

sort -t: -k3 /etc/passwd

uniq [OPTION]... [INPUT [OUTPUT]]  报告或移除重复的行

  • -c:显示每行的重复次数;
  • -u:仅显示未曾重复过的行;
  • -d:仅显示重复过的的行;

diff:compare files line by line 按照每行比较两个文件的差异

diff [OPTION]... FILES

diff /etc/passwd /etc/pam.d/

 

posted @ 2019-10-05 10:39  Crazymagic  阅读(181)  评论(0编辑  收藏  举报