固定長ファイルの特定の位置にある特定の行の文字列を置き換える

固定長ファイルの特定の位置にある特定の行の文字列を置き換える

レコードにタグ付きの固定長データファイルがあり(最初の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" ))を使用できます。

関連情報