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

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

新規登録して質問してみよう
ただいま回答率
85.48%
bash

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

Ubuntu

Ubuntuは、Debian GNU/Linuxを基盤としたフリーのオペレーティングシステムです。

Q&A

解決済

1回答

348閲覧

historyにコマンドの実行時間を付けて表示したい

pecchan

総合スコア555

bash

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

Ubuntu

Ubuntuは、Debian GNU/Linuxを基盤としたフリーのオペレーティングシステムです。

0グッド

0クリップ

投稿2023/05/14 21:38

Ubuntu
16.04.7 LTS (Xenial Xerus)

historyに、コマンドの実行時間を付けて表示したいのですが、

HISTTIMEFORMAT='%Y-%m-%d %H:%M:%S' history

としますと、↓のように全て現在時刻になってしまいます。

495 2023-05-15 06:25:07tail -f log/staging.log 496 2023-05-15 06:25:07exit 497 2023-05-15 06:25:07cd app/current 498 2023-05-15 06:25:07tail -f log/staging.log 499 2023-05-15 06:25:07history | grep rails 500 2023-05-15 06:25:07RAILS_ENV=staging bundle exec rails c 501 2023-05-15 06:25:32history 502 2023-05-15 06:26:44HISTTIME

コマンドの実行時間を付けて表示する方法はないでしょうか?

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

クリップした質問は、後からいつでもMYページで確認できます。

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

setoppu

2023/05/15 04:13

設定したあとに実行したモノはどうでしょう? https://linuxfan.info/add-datetime-to-history >ただし、「HISTTIMEFORMAT」を設定する前のコマンドにも日時が表示されていますが、これは正しくありませんので注意してください。
guest

回答1

0

ベストアンサー

man bashより:

HISTTIMEFORMAT この変数に空でない値が設定されると、 組み込みコマンド history で 履歴エントリを表示するときに タイムスタンプを表示するための strftime(3) の書式文字列 として使われます。 この変数が設定される と、ほかのシェルのセッションでも使えるように タイムスタンプは履 歴ファイルに書き込まれます。 タイムスタンプはほかの履歴行と区別 するために履歴のコメントとなります。

設定したらタイムスタンプが書き込まれるというのは、設定する前はタイムスタンプが書き込まれていないと言うことです。

おそらく、実行中のシェルでHISTTIMEFORMAT='%Y-%m-%d %H:%M:%S'を実行してその直後に見たのでなく、設定ファイルに書いて、シェルを起動し直したのでしょう。
前回実行していたHISTTIMEFORMAT未設定のシェル終了時に書かれていた.bash_historyにはタイムスタンプ情報が無いので、そうなります。

実行中のシェルでそれまでセットされていなかったHISTTIMEFORMATをセットした場合は、セット後にhistoryコマンドを実行すると、そのシェルで実行したコマンドのヒストリーはメモリー中にあるので、セット以前のコマンドの時刻も表示されるはずです。
ただし沢山の履歴を表示させると、いま実行中のシェルで実行したコマンドでなく、前回シェルの書いた.bash_historyから読んだコマンドまで遡るかもしれませんが、それにはタイムスタンプ情報が無いので、正しく表示しようがないです。

なお、HISTTIMEFORMATの最後に空白を入れた方が見やすいです。

投稿2023/05/15 06:14

otn

総合スコア84555

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問