Suche nach Werten nach Zeichenfolgen - mehrere Spalten

Suche nach Werten nach Zeichenfolgen - mehrere Spalten

Ich habe diese Datei (output.txt):

    name:some name^M
    ^M
    count:1^M
    ^M
    region:some_region
    name:some name^M
    ^M
    count:2^M
    ^M
    region:some_region^M
    ^M
    name:some name^M
    ^M
    count:1^M
    ^M
    region:some_region^M
    ^M
 
Testing Powershell scripts execustions from Rundeck server against Windows server

So erhalten Sie nur Werte nach Name, Anzahl und Region

gewünschte Ausgabe:

some name 1 some region
some name 2 some region
some name 1 some region

mit grep -E 'name|count|region' output.txt | sed 's/^.*: //'

ich habe

some name
1
some_region
some name
2
some_region
some name
1
some_region

Wie erstelle ich mehrere Spalten?

Antwort1

Eine mögliche Antwort mit awk:

cat input | awk '/name: /{name=substr($0,7)} /count: /{cnt=substr($0,8)} /region:/{print name" "cnt" "substr($0,9)}' 

Antwort2

awk '/^(name|count|region):/{
         sep = (/^region/? ORS : OFS);
         gsub(/^[^:]+:[[:space:]]*|[[:space:]]*$/, "");
         printf "%s%s", $0, sep 
     }' file.txt

Danke an @RomanPerekhrest

verwandte Informationen