Linux の grep コマンドと egrep コマンドの詳細な説明

Linux の grep コマンドと egrep コマンドの詳細な説明

反復/egrep

構文: grep [-cinvABC] 'word' ファイル名

-c : 要件を満たす行の数を出力します
-i : 大文字と小文字を区別しない
-n: 要件を満たす行とともに行番号を出力します
-v : 要件を満たさない行を印刷する
-A : 数字(スペースの有無は問わない)が続きます。たとえば、A2は要件を満たす行とそれに続く2行を印刷することを意味します。
-B: 数字が続きます。たとえば、B2 は、要件を満たす行と上記の 2 行を印刷することを意味します。
-C: 後に数字が続きます (例: C2)。これは、要件を満たす行とその上下 2 行を印刷することを意味します。

'halt' を含む行とそれに続く 2 行を出力します。

[root@localhost ~]# grep -A2 'halt' /etc/passwd
停止:x:7:0:停止:/sbin:/sbin/停止
メール:x:8:12:mail:/var/spool/mail:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin

'halt' を含む行とその上の 2 行を出力します。

[root@localhost ~]# grep -B2 'halt' /etc/passwd
同期:x:5:0:sync:/sbin:/bin/sync
シャットダウン:x:6:0:シャットダウン:/sbin:/sbin/シャットダウン
停止:x:7:0:停止:/sbin:/sbin/停止

'halt' を含む行とその上下の 2 行を出力します。

特定のキーワードを含む行をフィルタリングし、行番号を出力する

[root@localhost ~]# grep -n 'root' /etc/passwd
1:root:x:0:0:root:/root:/bin/bash
11:オペレータ:x:11:0:オペレータ:/root:/sbin/nologin

特定のキーワードを含まない行をフィルタリングし、行番号を出力する

[root@localhost ~]# grep -nv 'nologin' /etc/passwd
1:root:x:0:0:root:/root:/bin/bash
6:sync:x:5:0:sync:/sbin:/bin/sync
7:シャットダウン:x:6:0:シャットダウン:/sbin:/sbin/シャットダウン
8:halt:x:7:0:halt:/sbin:/sbin/halt
26:test:x:511:511::/home/test:/bin/bash
27:test1:x:512:511::/home/test1:/bin/bash

数字を含むすべての行を除外する

[root@localhost ~]# grep '[0-9]' /etc/inittab
# upstart は動作します。init(5)、init(8)、initctl(8) を参照してください。
# 0 - 停止 (initdefault をこれに設定しないでください)
# 1 - シングルユーザーモード
# 2 - マルチユーザー、NFSなし(ネットワークがない場合は3と同じ)
# 3 - フルマルチユーザーモード
# 4 - 未使用
# 5 - X11
# 6 - 再起動 (initdefault をこれに設定しないでください)
id:3:initdefault:

数字を含まない行をすべて除外する

[root@localhost ~]# grep -v '[0-9]' /etc/inittab
# inittab はデフォルトのランレベルでのみ upstart によって使用されます。
#
# ここで他の構成を追加してもシステムには影響しません。
#
# システムの初期化は/etc/init/rcS.confによって開始されます
#
# 個々のランレベルは /etc/init/rc.conf によって開始されます
#
# Ctrl-Alt-Delete は /etc/init/control-alt-delete.conf によって処理されます
#
# 端末のgettyは/etc/init/tty.confと/etc/init/serial.confによって処理されます。
# /etc/sysconfig/init の設定に従います。
#
# Upstartイベントハンドラの書き方や、
#
# デフォルトのランレベル。使用されるランレベルは次のとおりです。
#

'#'で始まる行をすべて削除します

[root@localhost ~]# grep -v '^#' /etc/inittab
id:3:initdefault:

空白行と「#」で始まる行をすべて削除します

[root@localhost ~]# grep -v '^#' /etc/crontab |grep -v '^$'
シェル=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=ルート
ホーム=/

正規表現では、「^」は行の始まりを示し、「$」は行の終わりを示し、空白行は「^$」で表すことができます。英語の文字で始まっていない行を印刷するにはどうすればよいでしょうか。

[root@localhost ~]# vim test.txt
[root@localhost ~]# cat test.txt
123
アブ
456
翻訳:
#ラックス
全部

まず、実験のために test.txt に数行の文字列を書き込みます。

[root@localhost ~]# grep '^[^a-zA-Z]' test.txt
123
456
#ラックス
[root@localhost ~]# grep '[^a-zA-Z]' test.txt
123
456
翻訳:
#ラックス

数字の場合は、[0-9] の形式を使用します。もちろん、1 または 5 のみを含む [15] の形式を使用することもできます。この場合、15 とはみなされないことに注意してください。数字と大文字と小文字を除外したい場合は、[0-9a-zA-Z]と記述する必要があります。また、[ ] には [ ] 内の文字以外の文字を表す [^ 文字] という別の形式もあります。

任意の文字と繰り返し文字をフィルタリングする

[root@localhost ~]# grep 'r..o' /etc/passwd
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
ゴーファー:x:13:30:ゴーファー:/var/ゴーファー:/sbin/nologin
vcsa:x:69:69:仮想コンソール メモリ所有者:/dev:/sbin/nologin

. は任意の文字を表します。上記の例では、r と o の間にある 2 つの文字を含む行が除外されます。* は、先行する文字の 0 個以上を表します。

[root@localhost ~]# grep 'ooo*' /etc/passwd
ルート:x:0:0:root:/root:/bin/bash
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
メール:x:8:12:mail:/var/spool/mail:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin

「ooo*」は、oo、ooo、oooo ... または「o」の増加を意味します。では、「.*」の組み合わせが何を意味するか考えてみましょう。

[root@localhost ~]# grep '.*' /etc/passwd |wc -l
27
[root@localhost ~]# wc -l /etc/passwd
27 /etc/passwd

「.*」は、空白行を含む 0 個以上の任意の文字を意味します。

フィルタリングする文字の出現回数を指定します

[root@localhost ~]# grep 'o\{2\}' /etc/passwd
ルート:x:0:0:root:/root:/bin/bash
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
メール:x:8:12:mail:/var/spool/mail:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin

エスケープ文字\なしで-Eを使用することもできます。

grep -E 'o{2}' /etc/passwd

ここでは { } が使用され、内部の数字は前の文字が繰り返される回数を示します。上記の例では、2 つの o、つまり「oo」を含む行を意味します。 { } の両側にエスケープ文字 '\' が必要であることに注意してください。また、{ } を使用して範囲を表すこともできます。具体的な形式は '{n1,n2}' です。ここで、n1<n2 は前の文字を n1 回から n2 回繰り返すことを意味します。n2 は空にすることもできます。その場合は n1 回以上であることを意味します。

上で述べた grep は、よく使われるツールである egrep でもあります。簡単に言うと、後者は前者の拡張版です。egrep を使用すると、grep では実行できないタスクを実行できます。もちろん、egrep は grep で実行できるタスクも実行できます。面倒だと感じる場合は、egrep について学習してください。grep の機能は日常業務には十分です。以下は、grep では使用されない egrep の使用法の一部です。テストの便宜上、test.txt を次の内容に編集します。

rot:x:0:0:/rot:/bin/bash
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
ルート:x:0:0:/ルート:/bin/bash
111111111111111111111111111111
ああああああああああああああ

1つ以上の先行文字をフィルタリングする

[root@localhost ~]# egrep 'o+' test.txt
rot:x:0:0:/rot:/bin/bash
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
ルート:x:0:0:/ルート:/bin/bash
[root@localhost ~]# egrep 'oo+' test.txt
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
ルート:x:0:0:/ルート:/bin/bash
[root@localhost ~]# egrep 'ooo+' test.txt
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
ルート:x:0:0:/ルート:/bin/bash

直前の文字の0回または1回の出現をフィルターします

[root@localhost ~]# egrep 'o?' test.txt
rot:x:0:0:/rot:/bin/bash
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
ルート:x:0:0:/ルート:/bin/bash
111111111111111111111111111111
ああああああああああああああ
[root@localhost ~]# egrep 'ooo?' test.txt
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
ルート:x:0:0:/ルート:/bin/bash
[root@localhost ~]# egrep 'oooo?' test.txt
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
ルート:x:0:0:/ルート:/bin/bash

フィルター文字列 1 または文字列 2

[root@localhost ~]# egrep 'aaa|111|ooo' test.txt
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
ルート:x:0:0:/ルート:/bin/bash
111111111111111111111111111111
ああああああああああああああ

egrep における ( ) の応用

[root@localhost ~]# egrep 'r(oo)|(at)o' test.txt
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
ルート:x:0:0:/ルート:/bin/bash

全体を表すには ( ) を使用します。たとえば、(oo)+ は 1 つの「oo」または複数の「oo」を意味します。

[root@localhost ~]# egrep '(oo)+' test.txt
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
オペレータ:x:11:0:オペレータ:/root:/sbin/nologin
ルート:x:0:0:/ルート:/bin/bash

以上が今回紹介したLinuxのgrepコマンドとegrepコマンドの関連知識の全てです。123WORDPRESS.COMをご愛顧いただき、誠にありがとうございます。

以下もご興味があるかもしれません:
  • Linux での grep コマンドの使い方の詳細な説明
  • Linux でタブと改行を一致させる Grep コマンド
  • Linuxはgrepを使用して複数の条件をフィルタリングし、grepの一般的なフィルタリングコマンドを使用します。
  • Linux で grep コマンドを使用してファイルの内容を取得する方法
  • Linux の一般的なコマンドと find と grep の違い
  • Linux テキスト フィルタリング grep 基本コマンドの紹介 (5)
  • Linux grepコマンドの詳細な説明
  • Linux の grep コマンドの詳細な理解
  • Linux での Grep コマンドの使用
  • Linux での grep コマンドの使い方の詳細な説明

<<:  Vue の foreach 配列と js の traversal 配列の書き方の説明

>>:  Mysql データベースの日付と日時型でデフォルト値 0000-00-00 を設定するときに発生するエラー問題の詳細な説明

推薦する

CSS カウンターとコンテンツの概要

コンテンツ プロパティは CSS 2.1 で導入され、:before および :after 疑似要素...

JS配列の次元削減のいくつかの方法の詳細な説明

2次元配列の次元削減配列インスタンスメソッド concat と ES6 スプレッド演算子を使用した次...

MySQLの重複排除方法

MySQLの重複排除方法【初級】繰り返しのセリフが少ないdistinctive を使用してそれらを見...

Dockerの基礎

序文: Docker はオープンソースのアプリケーション コンテナ エンジンであり、開発者はこれを使...

音声キューイングシステムを実装するためのJavaScript

目次導入主な特徴エフェクト表示キーコード導入音声キューイングシステムは、銀行、レストラン、病院などの...

レンダリング関数と JSX の詳細

目次1. 基本2. ノード、ツリー、仮想DOM 1. 仮想DOM 3. createElementパ...

ネイティブ JS を使用してタッチスライド監視イベントを実装する方法

序文今日はちょっとしたデモを書きました。左右にスワイプするロジックに関わる部分があります。当初はプラ...

CSS3で蓮の花が咲くアニメーション効果を実現

まずは効果を見てみましょう:この効果は非常に華やかに見えますが、原理は複雑ではありません。1 枚の花...

React Nativeプロジェクトフレームワークの構築経験

React Native は、2015 年 4 月に Facebook によってオープンソース化され...

Centos での TCPWrappers アクセス制御の実装

1. TCP ラッパーの概要TCP Wrappers は TCP サービス プログラムを「ラップ」し...

Vue は div の高さをドラッグ可能にします

この記事では、divのドラッグ可能な高さを実現するためのVueの具体的なコードを参考までに共有します...

Vueプロジェクトはログインと登録の効果を実現します

この記事の例では、ログインと登録の効果を実現するためのvueプロジェクトの具体的なコードを共有してい...

JavaScriptの再帰の詳細

目次1. 再帰とは何ですか? 2. 再帰を使って数学の問題を解く1. 1 * 2 * 3 * 4 …...

IDEAでVUEプロジェクトをデバッグするための詳細な手順

js コードをデバッグするには、コード内にデバッガーを記述するか、Chrome で毎回ブレークポイン...

一般的でない js 演算演算子の概要

目次2. カンマ演算子3. JavaScript Null 結合演算子 (??) 4. JavaSc...