Linuxで特定の区間の行を表示する方法

Linuxでファイルの特定の区間の行を表示する必要がある場合は、さまざまなコマンドを利用できます。この記事では、`sed`, `awk`, `head`, `tail`などのコマンドを使って、ファイルから指定された行を抽出する方法について詳しく解説します。さらに、実際の応用例も4つ紹介するので、コマンドの理解と実用性が高まるでしょう。

目次

基本的な方法

### `sed`コマンドを使う

`sed`は、テキストのストリームエディタです。以下のコマンドで、ファイルの5行目から10行目までを表示できます。

sed -n '5,10p' filename  # filenameの5行目から10行目までを表示

オプションと引数の説明

– `-n`: このオプションは、何も出力しないように`sed`に指示します。
– `’5,10p’`: これは、5行目から10行目までを`p`(印刷)コマンドで出力するように指示します。

### `awk`コマンドを使う

`awk`はテキスト処理のプログラム言語の一つです。同じことを`awk`で行うには以下のようにします。

awk 'NR>=5&&NR<=10' filename  # filenameの5行目から10行目までを表示

オプションと引数の説明

- `NR`: これは`awk`の内部変数で、現在処理しているレコード(通常は行)の番号です。
- `>=5&&<=10`: この条件は、行が5以上10以下である場合にその行を出力するという意味です。

応用例

1. テキストファイルから特定の単語が含まれる行を抽出する

grep 'keyword' filename | sed -n '5,10p'  # keywordが含まれる行を抽出した後、5行目から10行目までを表示

2. 複数のファイルから特定の行を抽出する

awk 'NR>=5&&NR<=10' filename1 filename2  # filename1とfilename2の5行目から10行目までを表示

3. 行番号を表示しながら特定の行を抽出する

awk 'NR>=5&&NR<=10 {print NR, $0}' filename  # 行番号も一緒に表示

4. ログファイルから時間帯に応じて行を抽出する

awk '/22:00:00/,/23:00:00/' logfilename  # 22時から23時までのログを抽出

まとめ

Linuxにおいて、ファイルから特定の行を抽出する方法には様々な手法があります。`sed`や`awk`などのコマンドを理解することで、柔軟なテキスト操作が可能になります。特に、応用例を通して、さまざまなケースでどのように行を抽出できるかが理解できたのではないでしょうか。

created by Rinker
オライリージャパン
¥3,080 (2025/01/18 00:25:55時点 Amazon調べ-詳細)

コメント

コメントする

目次