awk druckt $2 nicht aus einer Datei?

awk druckt $2 nicht aus einer Datei?

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 awkhat immer nur eine Eingabespalte und $2ist daher immer null.

Antwort2

IFSteilt standardmäßig beim Leerzeichen auf, so dass Ihre forSchleife 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 forSchleife 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 echowä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

verwandte Informationen