私はヘッダー情報を出力するawkスクリプトを持っていて、次にcsvファイルをループしてxml出力を作成します。ループが完了した後に1行だけを出力したいのですが、次のスクリプトは、ファイルの最後ではなく各行の後にタグを置きます。何が間違っていますか?ファイルを実行するためにawkのループの後に1行を出力するにはどうすればよいですか?
sudo gawk -f tst.awk customers.csv
:私は、次のコマンドを使用し
BEGIN { FS="," }
NR==1 {
{print "<?xml version=\"1.0\" encoding=\"UTF-8\"?>" > "output.xml" }
{print "<Batch>" > "output.xml" }
{print " <ASWFileVersion>" > "output.xml" }
{print " <Application>Batch Maintenance</Application>" > "output.xml" }
{print " <FileFormat>BATCH_XML_01</FileFormat>" > "output.xml" }
{print " <Release> </Release>" > "output.xml" }
{print " </ASWFileVersion>" > "output.xml" }
{print " <BatchHeader>" > "output.xml" }
{print " <BatchId>965</BatchId>" > "output.xml" }
{print " <UserBatchId>965</UserBatchId>" > "output.xml" }
{print " <BatchType>O</BatchType>" > "output.xml" }
{print " <Description>Brdata Customer Import</Description>" > "output.xml" }
{print " <CreatedOn>2014-12-05T12:35:30.3930000-05:00</CreatedOn>" > "output.xml" }
{print " <TargetData>BatchCustomer</TargetData>" > "output.xml" }
{print " <SaleLevel>0</SaleLevel>" > "output.xml" }
{print " <Status> </Status>" > "output.xml" }
{print " <ErrorMessage> </ErrorMessage>" > "output.xml" }
{print " </BatchHeader>" > "output.xml" }
for (i=1; i<=NF; i++) {
tags[i] = $i
}
next
}
{
print "<BatchCustomer>" > "output.xml"
for (i=1; i<=NF; i++) {
printf " <%s>%s</%s>\n", tags[i], $i, tags[i] > "output.xml"
}
print "</BatchCustomer>" > "output.xml"
}
{print "</Batch>" > "output.xml" }
。入力ファイルはcustomers.csvで、ファイルにはタグとなるヘッダーがあります。このスクリプトは、output.csvというファイルを生成します。私は、ファイルの一番下にタグを置く必要があり、行から生成される各セグメントの最後ではありません。私が間違っていたアイデアは何ですか?
各 'print'ステートメントの周りの' NR == 1'ブロック内の中カッコは何も役立たない。 – tripleee