質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

91.87%

  • Linux

    2157questions

    Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

  • bash

    362questions

    bash(Bourne-again-Shell)は sh(Bourne Shell)のインプリメンテーションに様々な機能が追加されたシェルです。LinuxやMac OS XではBashはデフォルトで導入されています。

シェルスクリプトのコマンド出力について

解決済

回答 2

投稿 2017/02/16 23:11

  • 評価
  • クリップ 0
  • VIEW 150

430430Wt

score 26

いつもお世話になっております。

シェルスクリプトを書いているのですが

スクリプト内で
cd /home/ 
ls -ltr > /tmp/test.log
という感じで書いているのですが
logファイルにはlsの出力結果が書かれます。

実現したいことは
ls -ltr というコマンドを打ったことをログに出力させたいです。

cat /tmp/test.log
ls -ltr
-rwxrwxrwx...(略)
という風に打ったコマンド+出力結果となるようにしたいです。

できる方法はありますでしょうか?
今の所
echo ls -ltr
ls -ltr 
位しか思い付きませんでした。
ご存知の方いらっしゃいますでしょうか?

  • 気になる質問をクリップする

    クリップした質問に回答があった場合に通知・メールを受け取ることができます。

    クリップした質問はマイページの「クリップ」タブからいつでも見ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

+3

下記に同様の話題がありました。
http://stackoverflow.com/questions/2853803/in-a-shell-script-echo-shell-commands-as-they-are-executed

これによると、あなたの求めている挙動は-vオプションで実現できるようです。

具体的には以下のように、いくつかの適用方法があるようです。

  • シェルスクリプト1行目を「#!/bin/bash -v」にする
  • シェルスクリプトに「set -v」を追記する
  • 「bash -v script.sh」のように起動する

投稿 2017/02/17 00:03

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    以下のような回答は評価を下げられます

    • 間違っている回答
    • 質問の回答になっていない投稿
    • 不快な投稿

    評価を下げる際はその理由をコメントに書き込んでください。

  • 2017/02/17 10:52 編集

    この方法を使用してもスクリプト内に記述したリダイレクトでは実行コマンドは出力されないと思います。

    $ ls -ald test.sh
    -rwxrwxr-x 1 hoge fuga 50 2月 17 10:47 2017 test.sh
    $ cat test.sh
    #!/bin/bash -v
    cd $PWD
    ls -ltr &> /tmp/test.log

    $ ./test.sh
    #!/bin/bash -v
    cd $PWD
    ls -ltr &> /tmp/test.log
    $ cat -n /tmp/test.log
    1 合計 4
    2 -rwxrwxr-x 1 hoge fuga 50 2月 17 10:47 2017 test.sh

    キャンセル

checkベストアンサー

+2

sh(bash)の実行時オプションで-x-vという物があります。違いは、-vがスクリプトに書いた通りに出力するのに対して、-xは変数展開やファイルマッチ展開などを全部して、最終的に実行されるコマンドラインを出力します。
出力は標準エラー出力に出されるので、標準エラーのリダイレクト指定が必要です。下記では&>

#!/bin/bash
cd /home/ 
bash -v -c 'ls -ltr' &> /tmp/test.log 

投稿 2017/02/17 10:04

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    以下のような回答は評価を下げられます

    • 間違っている回答
    • 質問の回答になっていない投稿
    • 不快な投稿

    評価を下げる際はその理由をコメントに書き込んでください。

  • 2017/02/18 00:19

    ありがとうございます!できました!

    キャンセル

teratailには29人のエキスパートがいます

今すぐはじめる

もっと詳しく

関連した質問

同じタグがついた質問を見る

  • Linux

    2157questions

    Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

  • bash

    362questions

    bash(Bourne-again-Shell)は sh(Bourne Shell)のインプリメンテーションに様々な機能が追加されたシェルです。LinuxやMac OS XではBashはデフォルトで導入されています。

閲覧数の多いLinuxの質問