このシェルスクリプトを実行しています。
#!/bin/sh
for line in `cat file.txt`
do
Am=`echo $line| awk '{print $1}'`
Bm=`echo $line| awk '{print $2}'`
#my command Am +Bm.......
done
私は最初の行でこれを得ます。
+ cat file.txt
+ echo A
+ awk {print $1}
+ AM=A
+ echo A
+ awk {print $2}
+ Bm=
ご覧のとおり、Bm値を取得できません。
$ cat file.txt
A 19
B 81
C 76
D 31
$ awk '{print $2}' file.txt
19
81
76
31
$ awk '{print $1}' file.txt
A
B
C
D
答え1
for line in $(cat file.txt)
ファイル内の各globは1つずつ繰り返されます。送信された入力にはawk
入力列が1つしかないため、$2
常に空です。
答え2
IFS
デフォルトでは空白文字に分割されているので、for
ループは実際に各「単語」を繰り返します。
$ for x in `echo a 19 b whatever`; do echo $x; done
a
19
b
whatever
$
より良いアプローチは、次のことを介してfor
ループや役に立たないものを取り除くことです。cat
$ cat input
A 19
B 81
C 76
D 31
$ awk '{system("echo "$2" "$1)}' input
19 A
81 B
76 C
31 D
$
echo
代わりにあなたの「私の命令」はどこにあるのか…。
答え3
1つの方法は改行文字に設定することですIFS
。
set -f; # suppress wildcard expansion since `cat...` is unquoted
IFS=$'\n'; for line in `cat file.txt`; do
Am=`echo "$line" | awk '{print $1}'`
Bm=`echo "$line" | awk '{print $2}'`
#my command Am +Bm.......
done
しかし、他の方法もあります:
while read Am Bm junk; do
#my command Am +Bm....
done < file.txt