コマンド実行結果を標準出力とファイルの両方に出力する方法

コマンド実行結果を標準出力とファイルの両方に出力する方法

Posted at April 7,2020 11:55 PM
Tag:[Linux]

Linuxでコマンド実行結果を標準出力とファイルの両方に出力する方法を紹介します。

1.問題点

"ls -l"を実行するとファイル情報が標準出力で表示されます。

# ls -l
合計 12
-rw-r--r--. 1 root root 8  2月 13 17:40 2020 aaa
-rw-r--r--. 1 root root 8  2月 13 17:40 2020 bbb
-rw-r--r--. 1 root root 8  2月 13 17:40 2020 ccc

この結果を標準出力だけでなく、ファイルにも掃き出したいのですが方法が分かりません。

なお、事前にscriptコマンドは実行できないものとします。

またファイルにはコマンド実行結果以外の情報は含めないものとします。

ということで、コマンド実行結果を標準出力とファイルの両方に出力する方法を紹介します。

2.コマンド実行結果を標準出力とファイルの両方に出力する

コマンド実行結果を標準出力とファイルの両方に出力するには、次のコマンドを実行します。

# script -q -c "ls -l" /dev/null | tee result.txt

3.解説

scriptコマンドのオプションの意味は次の通りです。

  • -q:終了メッセージをなくす
  • -c コマンド:指定したコマンドだけをログに残す

このオプションを使えば、

# script -q -c "ls -l"

でも問題ないように思われますが、このコマンドを実行すると、typescriptファイルは、

スクリプトは 2020年02月13日 18時39分34秒
 に開始しました合計 12
-rw-r--r--. 1 root root 8  2月 13 17:40 2020 aaa
-rw-r--r--. 1 root root 8  2月 13 17:40 2020 bbb
-rw-r--r--. 1 root root 8  2月 13 17:40 2020 ccc
-rw-r--r--. 1 root root 0  2月 13 18:39 2020 typescript

となり、「スクリプトは~に開始しました」という余分なメッセージが含まれてしまいます。

これを回避するために、

# script -q -c "ls -l" /dev/null 

とし、結果をデフォルトのファイルに書き込まないようにします。

そして、teeは標準入力から読んだ内容を標準出力とファイルに書き出すコマンドで、scriptコマンドの結果をパイプでteeに渡すことで実現します。

# script -q -c "ls -l" /dev/null | tee result.txt

4.参考サイト

参考サイトは下記です。ありがとうございました。

関連記事
トラックバックURL


コメントする
greeting

*必須

*必須(非表示)


ご質問のコメントの回答については、内容あるいは多忙の場合、1週間以上かかる場合があります。また、すべてのご質問にはお答えできない可能性があります。予めご了承ください。

太字イタリックアンダーラインハイパーリンク引用
[サインインしない場合はここにCAPTCHAを表示します]

コメント投稿後にScript Errorや500エラーが表示された場合は、すぐに再送信せず、ブラウザの「戻る」ボタンで一旦エントリーのページに戻り(プレビュー画面で投稿した場合は、投稿内容をマウスコピーしてからエントリーのページに戻り)、ブラウザをリロードして投稿コメントが反映されていることを確認してください。

コメント欄に(X)HTMLタグやMTタグを記述される場合、「<」は「&lt;」、「>」は「&gt;」と入力してください。例えば「<$MTBlogURL$>」は「&lt;$MTBlogURL$&gt;」となります(全て半角文字)