bash パイプ 複数コマンド 組み合わせ

バイオインフォ道場、くまぞうです。

複数のコマンドを連続で処理すると、解析作業が効率的に進むときがあります。コマンドの出力結果をソートしたり、さらに絞り込みを行ったりするだけで、分り易い結果になることは良くあることかもしれません。そんなちょっとしたテクニックでは、パイプ(|)を使います。コマンドの結果出力(標準出力)を、次のコマンドへ直接渡すことができます。1つ1つのコマンドを使っても色々なことができますが、パイプを使って複数のコマンドを組み合わせることで、とても便利に使えるようになります。

スポンサーリンク



パイプの使い方

基本的な使い方

あるコマンドを実行し、その結果を次のコマンドで処理したいときにパイプを使います。例えば、コマンドの結果を、ソートしたり・絞り込みしたり・カウントしたり・置換や列の並び替えを行う機会は良くあります。複数のコマンドを組み合わせると色々なことが出来るようになります。

$ command1 | command2 ... | ...

こんなときはどうする?

  • ファイル内に同じ行が何個あるかを調べるには?

    ファイルをsortコマンドでソート後、uniqコマンドの-cオプションでカウントします。

    $ cat aaa.txt
    Hello A
    Hello B
    Hello C
    Hello C
    Hello B
    Hello B
    
    $ sort aaa.txt | uniq -c
      1 Hello A
      3 Hello B
      2 Hello C
          

  • ファイル内でキーワードに合致した行の前後を調べて、更にログに記録するには?

    ファイルの検索を行うにはgrepコマンドを使います。尚、該当行の前後にも注目したいときは、-A-Bなどのオプションを使うと便利です。該当行の存在を目視しつつ、ファイルに保存したければteeコマンドがオススメです。

    $ seq 1 20 | grep 10 -A1 -B1 | tee log.txt
    9
    10
    11
    
    $ cat log.txt
    9
    10
    11
          

  • ファイル比較のためのsort・grep等の中間ファイルが面倒。簡単にできない?

    ファイルの比較にはdiffコマンドを使います。また、同時に良く使われるのがgrepsortコマンドです。しかし、これらをうまく活かすには一時ファイルを自ら準備する必要があります。このような場合に便利なのがプロセス置換です。パイプ機能と組合せて使うことが多いので、簡単な例を紹介します。プロセス置換とは、内部的な一時ファイルまたは名前付きパイプなどを利用し、それをコマンドの引数として渡す仕組みです。使い方に慣れれば、面倒な処理も一気に処理できるようになるかもしれませんよ。

    aaa.txtとbbb.txt、2つのファイルは「A」を含む行について、ソートして比較すれば同じ。実際に、ソートして、絞り込みを行ったファイルを比較します。今回は、プロセス置換<(...)を使うことで、中間ファイルを省略してみようと思います。

    $ cat aaa.txt
    Hello AA
    Hello AB
    Hello AC
    Hello BB
    
    $ cat bbb.txt
    Hello AC
    Hello AB
    Hello AA
    Hello BB
    
    $ diff <( grep A aaa.txt | sort ) <( grep A bbb.txt | sort )
    $ ## 相違なしで、相違点の表示は無し
          

[amazonjs asin="4797382384" locale="JP" title="Linuxコマンドブック ビギナーズ 第4版 (コマンドブックシリーズ)"]

スポンサーリンク





ピックアップ記事

  1. R plot 重ねる方法3パターン サンプルでわかるRの使い方

    Rでグラフ (plot) を重ねる方法は、「単純な追加」「図に重ねて描画」「濃淡で重なり表現」の3…
  2. R 使い方 グラフの色 自作のカラーパレットとデフォルトのカラーパレット

    グラフを描画する際、色の組み合わせを1つ1つ考えるのは面倒ですよね。Rには、あらかじめ色の組み合わ…
  3. awk split サンプルでわかる列の分割とセパレータ(文字・正規表現)の指定方法

    awkのsplit関数は、セパレータを指定して文字列を分割することができます。セパレータには文字や…

人気記事

  1. IGV, 解析ツール

    IGV 使い方 インストール〜便利な使い方まで | リファレンス・マッピングデータ・アノテーションを読み込んで表示しよう
    IGV(Integrative Genomics View…
  2. Excel, その他, 統計

    z-score 計算方法 エクセル(Excel) 編
    統計処理で、大きく変化しているなどの判断基準にも使われる値…
  3. R データ型 - 文字列・ベクター・データフレーム・マトリックス など-, R言語, スクリプト

    R subset関数 データフレームやmatrixからの条件指定による行・列の抽出
    R の subset関数は、データフレームやマトリックスか…

おすすめ記事

  1. R言語, グラフ

    R 使い方 軸・ラベルの調整(向き・サイズ・色など) グラフの描き方
    Rによるplot(グラフ)の描画は、手軽で大変便利です。た…
  2. bash 応用, シェルスクリプト

    シェル スクリプト ファイル存在チェック・空のファイルチェック
    bashでスクリプトを作成するときに、よく使うのがファイル…
  3. awk, bash 文字列操作, シェルスクリプト

    bash 部分文字列・置換・長さ・連結・分割の文字列処理
    bashのよく使う文字列処理、部分文字列・置換・連結・長さ…