生のテキスト データからバルク エントリ ファイルをフォーマットする必要がありました。を使用してソリューションの大部分を達成することができましたSed
. 次の入力[はるかに大量の]を解析しようとしてブランチに夢中になったときに、問題が明らかになりました。
---- Start Product ----
PartNumber>> 123457
Size04_Req>> 2
Size02_Req>> 1
PartColor>> Natural
PartDescription>> Guys Tee
---- End Product ----
---- Start Product ----
PartNumber>> TPIOO9205
Size05_Req>> 1
PartColor>> Natural
PartDescription>> Black Hoodie
---- End Product ----
###...with the objective of achieving the following output:
---- Start Product ---
PartNumber>> 123457
Size01_Req>> 0
Size03_Req>> 0
Size05_Req>> 0
Size06_Req>> 0
Size04_Req>> 2
Size02_Req>> 1
PartColor>> Natural
PartDescription>> Guys Tee
---- End Product ----
---- Start Product ----
PartNumber>> TPIOO9205
Size01_Req>> 0
Size02_Req>> 0
Size03_Req>> 0
Size04_Req>> 0
Size06_Req>> 0
Size05_Req>> 1
PartColor>> Natural
PartDescription>> Black Hoodie
---- End Product ----
これは、アドレス範囲/----\ Start\ Product\ ----/,/----\ End\ Product\ ----/内で作業し、いくつかのエレガントなブランチを実行するのと同じくらい簡単だと思います:label 作業ですが、明らかに、私の傾向は、このロジックのために Awk などにジャンプすることです。しかし、セドと一緒にいたいという当初の願望に固執し、いつでも新しいセドのトリックを学びたいので、これをどのように行うことができますか? ロジックは、 説明されていないサイズ 01-06 に対してSizeXX_Req>> 0を挿入することであり、順序は重要ではないことに注意してください. 少なくとも 1 つのSizeXX_Reqが常に存在します。各 Start/End Product セクションの間に行を挿入します。Sed(i) マスターはこれを素早く処理できますか? 最近書いている正規表現のボートロードから抜け出し、簡単な修正を見逃しているだけですか?
どうぞ。あなたがどのように(またはなぜ)したかを説明することさえせずに、別のランド言語で私を見せてください。私もそれでダウンしています. 前もってありがとう、のぞき見。