今回は Linux の grep と 正規表現 の使い方についてお届けします Linux の grep と正規表現を使用する際の 注意事項 は何ですか? 以下は実際的なケースです。
grep の概要
grep は、正規表現を使用してテキストを検索し、一致する行を出力できる強力なテキスト検索ツールです。通常、grep には grep、egrep (grep -E と同等)、fgrep の 3 つのバージョンがあります。 egrep は拡張 grep で、fgrep は高速 grep (テキストを検索するための固定文字列、正規表現参照はサポートしていませんが、クエリは非常に高速です) です。 grep は Linux テキスト処理の三銃士の 1 つです。
grep の使い方
使用方法:
grep [OPTIONS] PATTERN [FILE...]
grep [OPTIONS] [-e PATTERN | -f FILE] [FILE...]
共通オプション:
--color=auto: 一致したテキストに色を付けて強調表示します
-i: 文字の大文字と小文字を無視します
-o: 一致した文字列のみを表示します
-v: パターンに一致しない行を表示します
-E: 拡張正規表現の使用をサポートします
- q: サイレントモード、つまり情報は出力されません
-A #: パターンに一致した行とその後の # 行を表示
-B #: パターンに一致した行とその前の # 行を表示
-C #: パターンに一致した行とその前の# 行を表示その前後の行 #Line
注: grep を使用して照合する場合は、システムがパラメータまたは特殊コマンドと間違えてエラーを報告しないように、二重引用符 (一重引用符は強力な引用符) を使用する必要があります。
拡張 grep 使用法
使用法:
egrep [OPTIONS] PATTERN [FILE...] grep -E [OPTIONS] PATTERN [FILE...]
-i: 文字の大文字と小文字を無視します
-o: 一致した文字列自体のみを表示します
-v: パターンに一致しない行を表示します
-q : サイレントモード、つまり情報を出力しません
-A #: パターンに一致した行とその # 行目以降を表示します
-B #: パターンに一致した行とその前の # 行目を表示します
-C #: パターンに一致した行とその前後の # 行を表示します
-G: 基本的な正規表現をサポートします
grep 正規表現メタ文字
'^': 行頭のアンカー
' $': アンカー行末
'.': 任意の文字に一致
'*': 0 個以上の前の文字に一致
'?': 前の文字に 0 回または 1 回一致
'+': 一致前の文字を 1 回以上
: 前の文字を m 回一致させます (エスケープ文字の場合)
: 前の文字を少なくとも m 回一致させます。最大 n 回
[]': 指定範囲内の文字に一致 | '[^]' 指定範囲外の任意の 1 文字に一致
'<' または 'b': 単語の先頭にアンカー>' または 'b': アンカー単語末尾 (利用可能
'()': 複数の文字を全体として扱います
後方参照: 前のグループ化を参照します括弧内のパターン
グループ括弧内のパターンと一致するコンテンツは、正規表現エンジンによって内部変数に自動的に記録される場合があります:
1: パターンは左から始まり、最初の左括弧とパターンに一致するコンテンツ対応する右括弧の間
2: パターンは左から始まり、2 番目の左括弧と対応する右括弧の間のパターンと一致するコンテンツ...
拡張正規表現 式は正規表現とは少し異なります。
[]': 指定された範囲内の任意の 1 文字と一致しますが、特別な一致方法が多数あります。
[:digit:] は任意の 1 桁の数字と一致します
[: lower:] は任意の 1 つの小文字と一致します
[:upper:] 匹配任意单个大写字母
[:alpha:] 匹配任意单个字母
[:alnum:] 匹配任意单个字母或数字
[:punct:] 匹配任意单个符号
[:space:] 匹配单个空格
一些地方取消了转义字符的使用:
‘?‘:匹配其前面的字符0次或者1次;
‘+':匹配其前面的字符1次或者多次;
‘{m}‘:匹配其前面的字符m次(\为转义字符)
‘{m,n}':匹配其前面的字符至少m次,至多n次
():将一个或多个字符捆绑在一起,当做一个整体进行处理,反向引用照常使用。
‘|':或(注:‘C|cat'为C与cat,‘(C|c)at才是Cat与cat')
练习题:
1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次
[root@localhost ~]# who | cut -d' ' -f1|uniq root
2、取出最后登录到当前系统的用户的相关信息
[root@localhost ~]# id `last | head -1 | cut -d' ' -f1` uid=0(root) gid=0(root) groups=0(root)
3.取出当前系统上被用户当做其默认shell最多的那个shell
[root@localhost ~]# cut -d':' -f7 /etc/passwd|uniq -c|sort -n|tail -1|cut -d' ' -f7 /sbin/nologin
4.将/etc/passd中的第三个字段设置最大的后10个用户的信息全部改为大写保存至/tmp/maxuser.txt文件中
[root@localhost ~]# sort -t':' -k3 -n /etc/passwd|tail -10|tr 'a-z' 'A-Z' >/tmp/maxusers.txt [root@localhost ~]# cat /tmp/maxusers.txt NOBODY:X:99:99:NOBODY:/:/SBIN/NOLOGIN SYSTEMD-NETWORK:X:192:192:SYSTEMD NETWORK MANAGEMENT:/:/SBIN/NOLOGIN NGINX:X:996:994:NGINX WEB SERVER:/VAR/LIB/NGINX:/SBIN/NOLOGIN CHRONY:X:997:995::/VAR/LIB/CHRONY:/SBIN/NOLOGIN POLKITD:X:998:996:USER FOR POLKITD:/:/SBIN/NOLOGIN SYSTEMD-BUS-PROXY:X:999:997:SYSTEMD BUS PROXY:/:/SBIN/NOLOGIN DINGJIE:X:1000:1000:DINGJIE:/HOME/DINGJIE:/BIN/BASH JEFF:X:1001:1024:WOSHIDASHUAIBI:/HOME/JEFF:/BIN/BASH EGON:X:1002:1002::/HOME/EGON:/BIN/BASH NFSNOBODY:X:65534:65534:ANONYMOUS NFS USER:/VAR/LIB/NFS:/SBIN/NOLOGIN
5.取出当前主机的IP地址
[root@localhost ~]# ifconfig | egrep "inet.*broadcast.*"|cut -d' ' -f10 192.168.0.133
6.列出/etc目录下所有已.conf结尾的文件的文件名,并将其名字转换为大写后保存至/tmp/etc.conf文件中
[root@localhost ~]# find /etc -name '*.conf' | egrep -o "[^/]*(\.conf)$"|tr 'a-z' 'A-Z' >/tmp/etc.conf [root@localhost ~]# cat /tmp/etc.conf RESOLV.CONF CA-LEGACY.CONF FASTESTMIRROR.CONF LANGPACKS.CONF SYSTEMD.CONF VERSION-GROUPS.CONF LVM.CONF LVMLOCAL.CONF ASOUND.CONF LDAP.CONF MLX4.CONF RDMA.CONF SMTPD.CONF
7.显示/var目录下一级子目录或文件的总数
[root@localhost ~]# ls /var | wc -l
8.取出/etc/group第三个字段数值最小的10个组的名字
[root@localhost ~]# sort -t: -k3 -n /etc/group|head -10 |cut -d':' -f1 root bin daemon sys adm tty disk lp mem kmem
9.将/etc/fstab和/etc/issue文件的内容合并为同一个内容后保存至/tmp/etc.test文件中
[root@localhost ~]# cat /etc/fstab /etc/issue > /tmp/etc.test [root@localhost ~]# cat /tmp/etc.test # # /etc/fstab # Created by anaconda on Sat May 13 10:12:58 2017 # # Accessible filesystems, by reference, are maintained under '/dev/disk' # See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info # /dev/mapper/cl-root / xfs defaults 0 0 UUID=2789d01a-4e2b-47a5-9c3c-537641648663 /boot xfs defaults 0 0 /dev/mapper/cl-swap swap swap defaults 0 0 \S Kernel \r on an \m
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
以上がLinux grep と正規表現の使用の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。