ホームページ  >  記事  >  運用・保守  >  Linuxのgrepと正規表現に関するコード事例を詳しく解説

Linuxのgrepと正規表現に関するコード事例を詳しく解説

黄舟
黄舟オリジナル
2017-07-26 16:03:131518ブラウズ

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 #: パターンに一致した行と前後 # 行を表示します

: grep マッチングを使用する場合は、double を使用する必要があります引用符 (一重引用符は強力です) 参照) を使用して、システムがパラメーターまたは特殊なコマンドと誤ってエラーを報告するのを防ぎます。

拡張 grep 使用法

使用法: egrep [OPTIONS] PATTERN [FILE...]

grep -E [OPTIONS] PATTERN [FILE...]

-i: 文字サイズを無視します。
-o: 一致した文字列そのもののみを表示します
-v: パターンと一致しない行を表示します
-q: サイレントモード、つまり情報は出力されません
-A #: パターンとその-B で一致した行を表示します#: パターンと一致した行と前後 # 行を表示 -C #: パターンと一致した行と前後 # 行を表示
-G: 基本的な正規表現をサポート

grep 正規表現 数式文字

'^': 行頭のアンカー

'$': 行末のアンカー

'.': 任意の 1 文字と一致

'*': 0 個以上の前の文字と一致

' ?': 前の文字と 0 回または 1 回一致します;

'+': 前の文字と 1 回以上一致します。 m,n}': 前の文字と少なくとも m 回、最大で n 回一致します。 '[]': 指定された範囲内の文字と一致します。 '[^]' 指定された範囲外の文字と一致します。

の任意の 1 文字 | 'dec46d9b4aeb9cfed3f3e63004e9235b' または 'b': 単語の末尾をアンカー (利用可能 cd22d989ebecf0466bc673f30afdaf24: 単語全体と一致)

'()':複数の文字を全体として扱います

後方参照: 前のグループ括弧内のパターンと一致する文字を参照します

グループ括弧内のパターンと一致するコンテンツは、正規表現エンジンによって自動的に記録される場合があります内部変数:

1: パターンは左から始まり、コンテンツは最初の左括弧と一致する右括弧の間のパターンと一致します

2: パターンは左から始まり、最初のコンテンツは一致しました2 つの左括弧と対応する右括弧の間のパターンによって...

拡張正規表現は正規表現とは少し異なります:

'[]': 指定された範囲に一致します。多くの特別なマッチング方法。 [:digit:] は任意の 1 桁の数字と一致します

[: lower:] は任意の 1 つの小文字と一致します [:alnum:] は任意の 1 つの文字または数字と一致します

[: punct:] は単一の記号に一致します

[:space:] は単一のスペースに一致します

いくつかの場所でエスケープ文字の使用がキャンセルされました: '?': その前の文字を 0 回または 1 回一致させます

; '+': 前の文字と 1 回以上一致します

'{m}': 前の文字と m 回一致します (エスケープ文字の場合)

'{m,n}': 少なくとも前の文字と一致しますm 回、最大でも n 回

(): 1 つ以上の文字を束ねて全体として処理し、通常どおり後方参照が使用されます。

|': or (

: 'C|cat' is C and cat, '(C|c)at is Cat and cat')

練習問題:

1. 現在のシステム上の数値を列挙してくださいログインしているすべてのユーザーのユーザー名 注: 同じユーザーが複数回ログインした場合、表示されるのは 1 回だけです

[root@localhost ~]# who | cut -d' ' -f1|uniqroot

2. 現在のシステムに最後にログインしたユーザーの関連情報を取り出します。

[root@localhost ~]# id `last | head -1 | cut -d' ' -f1`
uid=0(root) gid=0(root) groups=0(root)
3. 現在のシステムでほとんどのユーザーがデフォルトのシェルとみなしているシェルを取り出します

[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' ' -f10192.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 -l21

  8.取出/etc/group第三个字段数值最小的10个组的名字


[root@localhost ~]# sort -t: -k3 -n /etc/group|head -10 |cut -d':' -f1
root
bin
daemon
sys
adm
tty
disklpmem
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 0UUID=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

  对于正则表达式的使用需要多联系加强记忆,否则是用不好正则表达式的,在学习过程中切记多写多背。

以上がLinuxのgrepと正規表現に関するコード事例を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。