Ich führe dieses Shell-Skript aus
#!/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
Ich bekomme dies für die erste Zeile:
+ cat file.txt
+ echo A
+ awk {print $1}
+ AM=A
+ echo A
+ awk {print $2}
+ Bm=
wie Sie sehen, wird der Wert für Bm nicht erfasst
$ 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
Antwort1
for line in $(cat file.txt)
durchläuft nacheinander jeden einzelnen Glob in der Datei. Die gesendete Eingabe awk
hat immer nur eine Eingabespalte und $2
ist daher immer null.
Antwort2
IFS
teilt standardmäßig beim Leerzeichen auf, so dass Ihre for
Schleife tatsächlich über jedes „Wort“ läuft
$ for x in `echo a 19 b whatever`; do echo $x; done
a
19
b
whatever
$
Ein besserer Ansatz könnte darin bestehen, sowohl die for
Schleife als auch die sinnlose Verwendung von cat
„via“ zu eliminieren, etwa so:
$ cat input
A 19
B 81
C 76
D 31
$ awk '{system("echo "$2" "$1)}' input
19 A
81 B
76 C
31 D
$
wo echo
wäre stattdessen Ihr „mein Befehl“ …
Antwort3
Eine Möglichkeit besteht darin, eine neue Zeile festzulegen 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
Es gibt jedoch auch andere Methoden:
while read Am Bm junk; do
#my command Am +Bm....
done < file.txt