テキスト検索必須コマンド-grep egrep fgrepの使い方と正規表現
一、grep、egrep、fgrepコマンド
本文では主にlinuxシステムの下でgrep egrep fgrepコマンドと正規表現の基本パラメータと使用フォーマット、方法を紹介した.(注記:本文中のfgは例を表し、)
1.1、基本定義:
grep(global search regular RE)and print out the lineは、正規表現を全面的に検索し、行を印刷する強力なテキスト検索ツールであり、基本的な正規表現を使用してテキストを検索し、一致する行を印刷するしかありません.
grepはよく見られるコマンドで、文字列データの比較を行い、ユーザーのニーズに合った文字列を印刷するのが主な機能ですが、grepはデータの中で文字列を検索するときに「行全体」単位でデータフィルタリングを行うことを考えています.
egrepコマンドはgrep-Eに等しく、このコマンドを使用して拡張された正規表現を使用してテキストを検索し、ユーザーのニーズに合った文字列を印刷することができます.
fgrepコマンドはgrep-Fに等しく、固定文字列を使用してテキストを検索しますが、正規表現の参照はサポートされていないため、このコマンドの実行速度も最も速いです.
1.2、命令基本用法
grep[option]'検索文字列'filename
grepの一般的なオプション:
二、正規表現
2.1、基本定義:
正規表現は、ある構文規則に合致する一連の文字列を記述し、一致させるために単一の文字列を使用する.多くのテキストエディタでは、正規表現は通常、あるモードに合致するテキストを取得、置換するために使用されます.簡単に言えば、正規表現は文字列を処理する方法であり、行為単位で文字列の処理を行い、いくつかの特殊な記号の補助を通じて、ユーザーが特定の文字列を簡単に検索/置換することができる.
正規表現は、基本的な正規表現と拡張された正規表現の2つに分類されます.
2.2、正規表現の詳細
2.2.1、基本的な正規表現:
(1)メタ文字:
(2)回数マッチング:
(3)文字アンカー:
2.2.2、拡張の正規表現:
拡張された正規表現は、基本的な正規表現に小さな修正を加えただけで、以下のように修正されます.
拡張の正規表現では()を()、{}を{}と書き、また+:回数マッチングを加え、その前の文字に少なくとも1回は一致し、上限なし、|:または(二取一)があり、残りは同じで、基本正規表現では(){}.?|を用いる.
(1)文字マッチングのコマンドと使い方は基本正規表現の使い方と同じであり,ここでは繰り返し説明しない.
(2)回数マッチング:
(3)文字アンカーの用法は基本正規表現の用法と同様であり,ここでは述べない.
(4)特殊文字:
三、grepコマンド利用小例
本文では主にlinuxシステムの下でgrep egrep fgrepコマンドと正規表現の基本パラメータと使用フォーマット、方法を紹介した.(注記:本文中のfgは例を表し、)
1.1、基本定義:
grep(global search regular RE)and print out the lineは、正規表現を全面的に検索し、行を印刷する強力なテキスト検索ツールであり、基本的な正規表現を使用してテキストを検索し、一致する行を印刷するしかありません.
grepはよく見られるコマンドで、文字列データの比較を行い、ユーザーのニーズに合った文字列を印刷するのが主な機能ですが、grepはデータの中で文字列を検索するときに「行全体」単位でデータフィルタリングを行うことを考えています.
egrepコマンドはgrep-Eに等しく、このコマンドを使用して拡張された正規表現を使用してテキストを検索し、ユーザーのニーズに合った文字列を印刷することができます.
fgrepコマンドはgrep-Fに等しく、固定文字列を使用してテキストを検索しますが、正規表現の参照はサポートされていないため、このコマンドの実行速度も最も速いです.
1.2、命令基本用法
grep[option]'検索文字列'filename
grepの一般的なオプション:
- -a : ,
- fg: /etc/inittab rc
- grep -a 'rc' /etc/inittab
- -c : ' '
- -i :
- -v : , ' '
- -o :
- -n :
- --colour(color):
- -A: n
- -B: n
- -C: n
二、正規表現
2.1、基本定義:
正規表現は、ある構文規則に合致する一連の文字列を記述し、一致させるために単一の文字列を使用する.多くのテキストエディタでは、正規表現は通常、あるモードに合致するテキストを取得、置換するために使用されます.簡単に言えば、正規表現は文字列を処理する方法であり、行為単位で文字列の処理を行い、いくつかの特殊な記号の補助を通じて、ユーザーが特定の文字列を簡単に検索/置換することができる.
正規表現は、基本的な正規表現と拡張された正規表現の2つに分類されます.
2.2、正規表現の詳細
2.2.1、基本的な正規表現:
(1)メタ文字:
- . :
- fg: student student
- grep ‘student.’ /etc/passwd // ,
-
- []: ,[abc],[a-z],[0-9],[a-zA-Z]
- fg:
- grep ‘[0-9]’ /etc/passwd
- [^]:
- fg: 。
- grep ‘[^a-z]’ /etc/inittab
- [:space:]:
- [:punct:]:
- [:lower:]:
- [:upper:]:
- [:alpha:]:
- [:digit:]:
- [:alnum:]: ----- [[:alnum:]]
(2)回数マッチング:
- * :
- fg: root 0 0
- grep ‘root*’ /etc/passwd
- .* :
- fg: root
- grep 'root.*' /etc/passwd
- \?: 1 0
- \{m,n\} : m, n )
(3)文字アンカー:
- ^: ,
- fg: #
- grep '^#' /etc/inittab
- $: ,
- fg: root
- grep 'root$' /etc/inittab
- ^$: ,
- \< \b: ,
- fg: root root
- grep '\<root' /etc/man.config
- \> \b: ,
- fg:\<root\> root grep "\<root\>" =grep "\broot\b"
2.2.2、拡張の正規表現:
拡張された正規表現は、基本的な正規表現に小さな修正を加えただけで、以下のように修正されます.
拡張の正規表現では()を()、{}を{}と書き、また+:回数マッチングを加え、その前の文字に少なくとも1回は一致し、上限なし、|:または(二取一)があり、残りは同じで、基本正規表現では(){}.?|を用いる.
(1)文字マッチングのコマンドと使い方は基本正規表現の使い方と同じであり,ここでは繰り返し説明しない.
(2)回数マッチング:
- * :
- ?: 0 1
- + : 1
- fg: : '[[:space:]]+'
- {m,n} : m n
(3)文字アンカーの用法は基本正規表現の用法と同様であり,ここでは述べない.
(4)特殊文字:
- | : 。
- fg:grep -E 'c|cat' file: file c cat
- \.:\ , .
三、grepコマンド利用小例
- (1) /etc/inittab # , ,
- grep '#[[:space:]]*[^[:space:]]' /etc/inittab
-
- (2)
- grep '^[0-9]’ /etc/passwd
-
- (3) 1 2
- grep '^\(1\|2\)' /etc/inittab grep -E '^(1|2)' /etc/inittab
-
- (4) rc /rc
- grep '.*\(rc\).*\/\1.*' /etc/inittab
-
- (5) IP
- ifconfig |grep -A 1 "^eth0" |grep "\<[0-9.]\{1,\} |cut -d: -f2
-
- (6) student( ) , /etc/passwd
- grep "^student" /etc/passwd
- (7) /proc/meminfo s
- grep -i '^s' /proc/meminfo grep '^[sS]' meminfo
- (8) /etc/inittab # , ,
- grep '^#[[:space:]]*[^[:space:]]' /etc/inittab
- (9) /boot/grub/grub.conf
- grep '^[[:space:]]\{1,\}' /boot/grub/grub.conf
- (10) /etc/inittab
- grep '^\([0-9]\).*\1$' /etc/inittab grep '^\([[:digit:]]\).*\1$' /etc/inittab
- (11) ifconfig 1-255
- ifconfig | egrep '\b[0-9][0-9]\b?|\b1[0-9][0-9]\b|\b2[0-4][0-9]\b|\b25[0-5]\b' --color
-