你的運動實際上是簡單地通過讀取每個行成單獨的變量處理,例如$a
,$b
,$c
,$d
和$e
。一旦閱讀,您可以用printf
的格式將它們寫入單獨的$count.geo
文件(例如1.geo
,2.geo
,...)中。一個簡單的實現是:
#!/bin/sh
dat=${1:-geo.dat} ## .dat filename ('geo.dat' default)
count=1
test -r "$dat" || { ## validate input file is readable
printf "error: file not readable '%s'\n" "$dat"
exit 1
}
while read -r a b c d e; do ## read each value into a b c d e
printf "x1 = %d;\nx2 = %d;\nx3 = %d;\nx4 = %d;\nx5 = %d;\n" \
$a $b $c $d $e >$count.geo
((count++))
done <"$dat"
使用awk
,你可以使用一個班輪類似:
awk '{printf "x1 = %d;\nx2 = %d;\nx3 = %d;\nx4 = %d;\nx5 = %d;\n", \
$1, $2, $3, $4, $5 > FNR".geo"}' geo.dat
例輸入文件geo.dat
$ cat geo.dat
5 9 4 4 2
8 4 3 8 7
5 8 4 3 7
1 3 9 8 2
5 8 2 2 1
7 1 8 3 4
3 7 4 7 2
5 6 6 9 5
3 4 4 8 6
2 9 9 1 7
2 6 5 4 8
5 1 9 4 3
4 6 1 7 5
2 4 1 7 3
6 2 6 1 9
3 3 9 3 4
6 5 9 2 8
8 7 8 8 2
1 2 9 1 1
4 3 5 5 1
8 2 2 5 3
2 7 5 1 1
9 6 5 9 8
4 9 6 2 8
8 3 1 7 4
2 1 6 7 7
7 5 9 9 9
2 3 7 8 3
9 8 1 5 7
9 9 7 6 1
6 4 5 7 2
8 9 3 6 6
示例使用
$ sh readgoedat.sh geo.dat
或
$ awk '{printf "x1 = %d;\nx2 = %d;\nx3 = %d;\nx4 = %d;\nx5 = %d;\n", \
$1, $2, $3, $4, $5 > FNR".geo"}' geo.dat
示例輸出文件過來,
$ cat 1.geo
x1 = 5;
x2 = 9;
x3 = 4;
x4 = 4;
x5 = 2;
$ cat 2.geo
x1 = 8;
x2 = 4;
x3 = 3;
x4 = 8;
x5 = 7;
$ cat 32.geo
x1 = 8;
x2 = 9;
x3 = 3;
x4 = 6;
x5 = 6;
看的東西,讓我知道,如果您還有其他問題。
你到目前爲止嘗試過什麼? '讀取-r行;做...',之前有'declare -i count'可以工作。 –
非常感謝您的回覆!我實際上嘗試過與DAKOTA一起提供的文件,但它不適用於我。如果你能提供你的想法的例子,將不勝感激。謝謝, – user3780018
注意答案是POSIX shell兼容。如果你有像bash這樣的高級shell,你可以選擇使用數組。無論哪種情況,您都可以使用* heredoc *而不是'printf'。 'awk'也提供了一個簡單的解決方案。 –