timeput
入力を1行ずつ読み、その各行の先頭に、読み取った時点の時刻をタブ区切りで出力する。
ただし、"-w 秒数" の指定により、1行読んで出力して、指定秒数動作を止める(sleepする)。
Ctrl+Z で操作を中断し、2次情報として何行まで読んだのかを表示する。
オプション :
-b 0 : 出力のバッファリングをしない。(Buffering)
-c STR : 色の指定。0で色無し。"cyan","faint red bold","bright_blue"など。色名はTerm::ANSIColor を参照。
-d : 日付も出力。yyyy-mm-dd HH:MM:SS 形式で。(date)
-g : 開始からの秒数でなくて、1行ごとの間隔秒数を表示。(gap)
-s : 起動してからの秒数を出力。(start)
--sleep N : 入力から1行ずつ逐次読み取り出力して、N秒停止することを繰り返す。
-z STR : タイムゾーンの設定。"Asia/Tokyo", "-9", "-9:00", "JST-9" などが設定できる。(システム依存)
-. N : 秒数を小数点以下 N 桁出力する。0から6の整数値が使える。未指定なら3。(-d とは両立しない。)
利用例 :
yes | head | timeput -.6
yes | head | timeput -d | sed 's/ /T/' # POSIXの日時形式にしたい場合。このsed文は最初の空白文字のみTに変更。
seq 5 | timeput -.6 | timeput -s.6 | timeput -g.6
seq 10 | timeput -w0.45 | timeput -g.3 # 0.45秒ずつ1行を読み取る。
command 1> output1.txt 2> >( timeput error.log ) # command は標準エラー出力に何か出力をするプログラムである。便利。
開発メモ:
* -w の動作を高度化したい。-w 2,0.2x10,0 と指定することで最初は2秒、次に10回は0.2秒、残りは即座のように。,は+、xは*でも可としたい。
* -3 のオプションを作りたい。timeput -3 で timeput -g | timeput -s | timeput とおなじ機能を持たせたい。
* 名前を timeput (タイムプット)ではなく、puttime の方が「プッタイム」で発音しやすい気がする。その方が記憶しやすいかも。
* タイムゾーンの設定について、 -z が明示的に必要なようだ (Macの場合)。
AUTHOR
下野寿之 Toshiyuki SHIMONO <bin4tsv@gmail.com>
COPYRIGHT AND LICENSE
Copyright (c) 2021-2023 Toshiyuki SHIMONO. All rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.