レコードにタグ付きの固定長データファイルがあり(最初の6文字にレコードを識別する特定の文字列がある)、特定の行とその行の特定の場所にあるテキストを置き換える必要があります。
HEADER 123456
SHIPTO CODE 123 LANE HOUSTON TX
ITEM ACME BRICK
たとえば、上記のデータの配送先住所コードを変更したいとします。データは配送履歴の場所10-17(「SHIPTO」で始まる行)にあります。 sedまたはawk(または他のコマンド)を使用したいのですが、単一のコマンドラインを使用してデータを更新したいと思います。 SHIPTO行が複数ある場合はすべて更新できます。
答え1
sedを使用してください:
$ sed -E '/^SHIPTO/ s/(.{9}).{8}/\1NuValue /' file
HEADER 123456
SHIPTO NuValue 123 LANE HOUSTON TX
ITEM ACME BRICK
仕組み:
/^SHIPTO/
これにより、次から始まる行が選択されます
SHIPTO
。これ変える次のコマンドは、これらの行にのみ適用されます。s/(.{9}).{8}/\1NuValue /
これにより、行の最初の9+8文字が一致し、行の最初の9文字がグループ1に格納されます。これらの文字はグループ1
\1
と新しい値(フォーマットを維持するには8文字でなければなりません)に置き換えられます。
答え2
与えられた入力ファイル:
HEADER 123456
SHIPTO CODE 123 LANE HOUSTON TX
ITEM ACME BRICK
最初のフィールドが「SHIPTO」の「Code」の後のフィールドを変更しようとしています。
$ awk 'BEGIN { OFS = "\t" } $1 != "SHIPTO" { print } $1 == "SHIPTO" { $3="0000"; print }' input
HEADER 123456
SHIPTO CODE 0000 LANE HOUSTON TX
ITEM ACME BRICK
フィールドが固定長で、スペースで区切られていてタブで区切られていない場合は、フォーマットされた印刷文字列(たとえばprintf( "%20s\t" "$1" )
)を使用できます。