
固定幅の文書があります。例は次のとおりです。
0196969696645001200 1100450000000000TEST1 / TECHNOLOTEST 97827Y
0196969696645001500 1100450000000000TEST222 EXPRESS - CMTEST 97827Y
0196969696600701325 7003150000000000TEST33333 70215U
0196969696621055400 1476210000000000TEST44444SE - CMC AUERSTEST 97803Y
メタデータファイルの例:
COL1,1,2
COL2,3,19
COL3,22,27
COL4,28,33
COL5,34,37
COL6,38,40
COL7,78,81
問題の説明:各列のメタデータファイル(開始位置と終了位置)を読み取り、固定幅ファイルを参照して各列のファイルを作成します。
私のコード:
feed_file=$1
metadata_file=$2
if [ $# -lt 2 ]
then
echo "Insufficient Number of Parameters passed"
echo "Usage <FEED FILE NAME> <META DATA FILE NAME>"
exit 1
fi
#Read metadata file and create feed file for each attribute
while read line
do
attrib_name=`echo $line | cut -d "," -f1`
beg_point=`echo $line | cut -d "," -f2`
end_point=`echo $line | cut -d "," -f3`
echo "$attrib_name || $beg_point || $end_point"
range=$beg_point-$end_point
cat $feed_file | cut -c $range > $attrib_name
done < $metadata_file
Error: cut: bad list for c option
答え1
テキストを処理するためにシェルループを使用しないでください、次のテキスト処理ツールを使用してくださいawk
。
awk -F, '
!meta_done{start[$1] = $2; len[$1] = $3 - $2 + 1; next}
{for (i in start) print substr($0, start[i], len[i]) > i}
' "$meta_file" meta_done=1 "$feed_file"
これには制限が$meta_file
あり、変数の割り当てのように設定する$feed_file
ことはできません。awk
と同じ名前のファイルがある場合は、代わりにmeta=data.txt
渡す必要があります。./meta=data.txt
awk
meta=data.txt