< pool.sam awk '
/./ {printf $1}
{printf $7+1,"\t"}
{printf $3,"\t"}
{
if($2 !=16) {print "\t", "+";} else {print "\t","-";}
{printf $4,"\t" ,length($10)+$4, "\t", "1"}
}'
私はすべての値を得ましたが、奇妙な方法で得ました。 7つの値を印刷しています。
値1値2値3値7
各行にTABで区切られた7つの値をすべて持ちたいです。
答え1
printf
あなたはこの仕事のために多くのことをしました。単に次のようなことをしたらどうでしょうか?
cat pool.sam |\
awk '/./ {printf $1,$7+1,"\t"$3,"\t",($2!=16)?"+","-",$4,"\t",length($10)+$4,"\t1"}}'
答え2
printf
それは印刷書式機能、print
接続パラメータ。
その機能(またはその両方)を確認する必要があるようですprintf
。
簡単に言うと:
printf <format, <parameter1>[, <parameter2>, ...] | text>
%
形式の文字表現これには次の形式のパラメータがあります。。フォーマットには特殊シーケンス(例:)を含めることができます\t
。\n
実際に Printfいいえ改行文字で出力を終了します。引数が1つだけ与えられると、通常はそのまま印刷されます。
数値の場合、デフォルトの形式は " %.6g
"です。
CODE : printf 1.123456789
RESULT: 1.12346
これは通常、$1
次1.123456789
のテキストで処理されます。
CODE : printf $1
RESULT: 1.123456789
CODE : printf $1+0 # Force conversion to number
RESULT: 1.12346
複数の引数を指定する場合は、最初の引数が型として使用され、残りは引数として使用されます。パターンを満たすために引数がほとんど与えられない場合、動作は次のようになります。はっきりしない。
printf "%d %s\n", 123, "hello"
|| | | | |
|| | | | +----- Parameter 2
|| | | +------------ Parameter 1
|| | +----------------- Print new-line
|| +------------------- Print parameter 2 as string
|+--------------------- Print literal space
+---------------------- Print parameter 1 as digit
printf "%d %s\n", 123, "hello"
# Gives: 123 hello
printf "%d %s\n", "hello", 123
# Gives: 0 123
printf "%d %s\n", 123
# Gives undefined result (according to format one parameter is missing)
プレースホルダなしで引数が指定されると、その引数は削除されます。
printf "%d", 123
# Gives: 123
printf "%d", 123, 22
# Gives: 123
printf "%d", 123, 22, "\t", "foo", 5566, 12.55, "\n", "blah"
# Gives: 123
キャラクター%
表現「変換仕様です」。awk
で定義されていないなど、誤った仕様が提供された場合指定されていない。他のテキストはプレーンテキストとして扱われます。
printf "Hello %w", "what"
# Usually: Hello %w
# But no guarantee
printf "ABC", "DEF", "GHI"
# Result: ABC
コードでは、ファイル入力をprintfの形式で使用することがよくあります。これらのフィールドの書式printf
が指定されていない場合は、プレーンテキストで印刷されます。パラメータは削除されます。
# Example, say:
# $4 = "%d %s\n"
# $8 = "33.2"
# $9 = "good"
printf $4, $8, $9
#
# Result: 33 good
# Say:
# $4 = "14"
# $8 = "33.2"
# $9 = "good"
printf $4, $8, $9
#
# Result: 14
printf $4, "\t", $8, "\t", $9
#
# Result: 14
スクリプト形式は次のとおりです。
< pool.sam awk '
# 1.
/./ { # IF line not empty THEN
printf $1 # print field 1
} # ENDIF
# 2.
{
printf $7 + 1, "\t" # printf with format = $7 + 1 and parameter <tab>
}
# 3.
{
printf $3, "\t" # printf with format = $3 and parameter <tab>
}
# 4.
{
# 4.1
if ($2 != 16) { # IF field 2 is not 16 THEN
print "\t", "+"; # print <tab> + "+" (Terminate with newline)
} else { # ELSE
print "\t", "-"; # print <tab> + "-" (Terminate with newline)
} # ENDIF
# 4.2
{
printf $4, "\t", length($10) + $4, "\t", "1"
# printf: pattern="field 4"
# parameters=<tab>, length of field 10 + field 4
}
}
'
あなたが持っているとしましょう:
$ cat pool.sam
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
これにより、次のようになります(上記のコードの数字を使用)。
1. printf "1"` => `1`
2. printf 8, "\t"` => `8`
3. printf "3", "\t" => `3`
4.1 print "\t", "+" => `<tab>+<new-line>`
4.2 printf "4", "\t", 6, "\t", "1" => `4`
最終結果:
183 +
4
書き直すと、次のような洞察が得られます。
awk '
/./ {
printf "%s%d\t%d\t", $1, $7 + 1, $3
if ($2 != 16) {
printf "+"
} else {
printf "-"
}
printf "%d\t%d\t1\n", $4, length($10) + $4
}
' pool.sam
if文(混乱の危険がある)を一度に作成することもできます。
printf "%s", $2 != 16 ? "+" : "-"
書式文字列とprintf
.aligned 書式を読み込むことは、浮動小数点書式と同様に、非常に便利な場合がよくあります。
right_pad=-10
printf "%*s: %5d\n", right_pad, "vix", 23
printf "%*s: %5d\n", right_pad, "popul", 336
printf "%*s: %5.2f\n", right_pad, "vidi", 42.129542488
printf "%5s %-10d +%d\n", "OK", 33, 44
出力:
vix : 23
popul : 336
vidi : 42.13
OK 33 +44
(少なくとも私が見つけた)最も簡単な方法は、ゲームをプレイしながらコマンドラインの代わりにスクリプトを使用することです。