CEOブログ

横浜で活躍するホームページ作成・開発会社アットライズの代表取締役社長(CEO)が綴る、日々の奮闘記!!

備忘録

[備忘録]bash:標準出力/エラー出力のリダイレクト

投稿日:2018年6月11日 更新日:

1333103-s

標準出力とエラー出力ではレイヤーが異なる

Bash(Linux)でコマンド操作をしているとき、通常の出力結果とエラー表示が混在して見にくくなることが多々ある。

また、出力結果をファイルにリダイレクトするようなとき、エラー表示がファイルに出力されず困った経験はないだろうか?

例えば、
—-
$ command > files.txt
—-
などとやると、正常結果はファイル「files.txt」に書き込まれるが、エラー表示は画面にのみ出力される。

実はBashでは、標準出力とエラー出力を分けて出力(表示)している。
ただ、普通に使っていると、シェルウィンド上では、どちらも混在して表示されているので、その違いを認識するのは難しいが。。

Photoshopのレイヤーが異なるようなイメージ

PhotoshopやIllustratorなどの画像ソフトを使った人なら「レイヤー」という概念をご存知だと思う。
レイヤーの感覚で説明すると分かりやすい。
・標準出力 :レイヤー1
・エラー出力:レイヤー2

これを切り分ける方法を。

エラー出力を標準出力に切り替える「2>&1」

—-
例)command > files.txt 2>&1
—-
解説:「出力2」(=エラー出力)を「出力1」(=標準出力)に切り替える。

これで、エラー出力も ファイル(files.txt)に書き込まれる。

エラー出力を表示させない「2>/dev/null」

もう一つ よく使う例として、そもそもエラーを表示させたくない時がある。
そんなときは、、
—-
例)command 2>/dev/null
—-
解説:「出力2」(=エラー出力)を「/dev/null」にリダイレクトする。
  ちなみに「/dev/null」とは、「NULLというデバイス」、つまり「何もない」ところにリダイレクトすることで 結果的に非表示となる。

これでOK!
 
 

-備忘録


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

関連記事

[備忘録]LINE通話の着信音を消す(カスタマイズ)する方法

人混みの中で、あの着信音はカンベンしてもらいたい。。 スマホの着信音、、いつまでも鳴り響くのがイヤなので、色々と細工してきた。(下記ブログ参照) [スマホ]自作:1回だけ音がしてあとは無音が長い着信音 …

[備忘録]Excel:開くと「PERSONAL.XLSBは編集のためロックされています」が出る

Excelウィンド 2つ目を開くと出る。。 ブログ[備忘録]Excelを複数の別ウィンドウで開く方法で、Excelを複数ウィンドで開く方法を書いた。 が、2つ目のウィンドを開くと「PERSONAL.X …

[備忘録]Windowsコマンド:フォルダごとコピーする方法(xcopy/robocopy)

エクスプローラだと大容量のコピーに膨大な時間がかかる。。 Windowsで複数ファイルをフォルダごとコピーしたいとき、エクスプローラー上でコピーすると、、 コピー対象が大容量の場合、メチャメチャ時間が …

[備忘録]さくらのメールからgmailへの転送ができない

Gmailのセキュリティ対策が強化された 今年の3月くらいから、どうやらGoogleのセキュリティ対策の一環で、Gmailのセキュリティ対策も強化された模様。 それに伴い、今までは問題なく送受信できて …

[備忘録]MySQL:バイナリログを自動削除する方法

サーバー容量を圧迫 サーバーの空き容量を毎日自動的にチェックしているが、 メインのサーバー容量が徐々に増えて、ついに87%まで来てしまった。。 90%を超えるとさすがにマズいので、何が圧迫しているか調 …