web-dev-qa-db-ja.com

3つの別々の列に出力を印刷する

MYPATH=/var/www/html/error_logs/
TOTALFILE=$(ls $MYPATH* | wc -l)
FILETIME=$(stat --format=%y $MYPATH* | head -5 | cut -d'.' -f1)  
FILE=$(ls -1tcr $MYPATH* | head -5 | rev | cut -d/ -f1 | rev)
TOPLINE=$(head -1 $MYPATH* | grep -Po '".*?"' | head -5)

この5つのファイル情報をヘッダー付きの列にエレガントに出力するにはどうすればよいですか?

FILE CREATED TIME   | FILE NAME        | ERROR HEADER
---------------------------------------------
$FILETIME           | $FILE            | $TOPLINE
2012-11-29 11:27:45 | 684939947465     | "SQLSTATE[HY000] [2002] Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)"

など5つのファイル

total files: $TOTALFILE

私が欲しいものを手に入れる簡単な方法はありますか?

注:この出力は、すべての変数をエコーすると得られます

2012-11-29 11:27:45 2012-11-29 11:27:41 2012-11-28 23:33:01 2012-11-26 10:23:37 2012-11-19 22:49:36
684939947465 1313307654813 1311411049509 1234980770182 354797376843
"SQLSTATE[HY000] [2002] Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)" "SQLSTATE[HY000] [2002] Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)" "Connection to localhost:6379 failed: Connection refused (111)" "An error occurred connecting to Redis." "SQLSTATE[HY000] [2002] Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)"
30
ADM

そのためにシェルコマンド 'column'を使用できます。以下を確認してください: column MAN page

これをループと組み合わせると、あなたはビジネスにいます、例えば:

#!/bin/sh

MYPATH=/
TOTALFILE=$(ls $MYPATH/* | wc -l)
FILE=$(ls -1tcr $MYPATH/* | head -5 | rev | cut -d/ -f1 | rev)

declare -a FILES
declare -a FILETIME

OUTPUT="FILENAME CREATED TIME ERROR_HEADER\n\n------------------------------ ----------------------------- ----------------------------------- ------$

for i in $MYPATH/*;
do
    FILES[${#FILES[@]}]="$i"
    FILETIME[${#FILETIME[@]}]=$(stat --format=%y $i | head -5 | cut -d'.' -f1)
    TOPLINE=$(head -1 $i | grep -Po '".*?"' | head -5)

    OUTPUT="$OUTPUT\n${FILES[${#FILES[@]}-1]} ${FILETIME[${#FILETIME[@]}-1]} $TOPLINE\n"
done

echo -ne $OUTPUT | column -t
28
QNimbus

printfの使用をお勧めします。例:

printf "%-30s | %-30s | %-30s" "$FILETIME" "$FILE" "$TOPLINE"

どこ %-30sは、文字列型の入力引数として30文字を予約することを意味します。 -は左揃えを示します。

31
Bernhard

私はループで行きます

printf " %-20s | %-20s | %-20s\n " FILE\ CREATED\ TIME FILE\ NAME ERROR\ HEAD
for i in "$MYPATH"/*
do
    printf "%-20s | %-20s | %-20s\n " $FILENAME $FILE $TOPLINE
done
printf "Total Files: %s" $TOTALFILES 
2
BitsOfNix

@qnimbusの回答はおそらくLinuxシステムに最適ですが、SunまたはIBM(2019年に1つを使用するのに十分/不幸な場合)このコマンド利用できない場合があります。代わりに prコマンド を使用して同じ効果を得ることができます。リンクされたページの例から、以下を使用できます。

pr -3 Word.lst | qprt

ファイルを印刷するWord.lst 3カラム。とは言っても、これはあなたの問題の解決策の一部にすぎません。

1
nonsensickle