Estou executando este script de shell
#!/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
Eu entendo isso na primeira linha:
+ cat file.txt
+ echo A
+ awk {print $1}
+ AM=A
+ echo A
+ awk {print $2}
+ Bm=
como você pode ver, não pega o valor de 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
Responder1
for line in $(cat file.txt)
irá iterar em cada glob do arquivo, um por um. A entrada enviada awk
terá apenas uma coluna de entrada, portanto $2
sempre será nula.
Responder2
IFS
divide por padrão o caractere de espaço para que seu for
loop realmente passe por cada "palavra"
$ for x in `echo a 19 b whatever`; do echo $x; done
a
19
b
whatever
$
Uma abordagem melhor seria eliminar o for
loop e o uso inútil de cat
algo como
$ cat input
A 19
B 81
C 76
D 31
$ awk '{system("echo "$2" "$1)}' input
19 A
81 B
76 C
31 D
$
onde echo
estaria o seu "meu comando" ...
Responder3
Uma maneira é definir IFS
uma nova linha:
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
Embora existam outros métodos também:
while read Am Bm junk; do
#my command Am +Bm....
done < file.txt