Shell脚本从所有文件中提取2个值?

时间:2013-07-10 01:49:45

标签: linux bash

我的目录中包含以下文件:

[Location]
state=California
city=Palo Alto

[Outlet]
id=23
manager=John Doe

我想写一个小脚本,为每个文件输出一行,如下所示:

John Doe,Palo Alto

我该怎么做?我怀疑有些grep和循环。到目前为止,我有:

#!/bin/bash
echo Manager,City > result.txt
for f in *.config
do
  cat "$f" | grep manager= >> result.txt
  cat "$f" | grep city= >> result.txt
done

但这当然是不完整的,因为grep在自己的行上返回整行,我只想在第一个=符号之后的部分。

3 个答案:

答案 0 :(得分:2)

echo Manager,City > result.txt

for f in *.config; do
    manager=$(awk -F= '$1=="manager" {print $2}' "$f")
    city=$(   awk -F= '$1=="city"    {print $2}' "$f")

    echo "$manager,$city"
done >> result.txt

awk -F=使用等号作为字段分隔符,然后检查所需的变量($1)并打印其值($2)。 $(cmd)捕获命令的输出并生成可分配给两个变量$manager$city的字符串。

答案 1 :(得分:2)

类似于John Kugelman's回答但使用grep

echo Manager,City > result.txt
for file in *.config; do 
    name=$(grep -oP '(?<=manager\=).*' "$file")
    location=$(grep -oP '(?<=city\=).*' "$file")
    echo "$name,$location"
done >> result.txt

答案 2 :(得分:1)

您可以使用单个awk命令执行此操作,具体如下:

pax> cat 1.config
[Location]
state=California
city=Palo Alto

[Outlet]
id=23
manager=John Doe

pax> cat 2.config
[Location]
state=Western Australia
city=Perth

[Outlet]
id=24
manager=Pax Diablo

pax> awk '
     /^city=/   {gsub (/^city=/, "", $0); city=$0}
     /^manager=/{gsub(/^manager=/, "", $0); print $0 "," city}
' *.config
John Doe,Palo Alto
Pax Diablo,Perth

请注意,这假设城市位于经理之前,并且所有文件都包含城市和经理。如果这些假设不正确,awk脚本会变得有点复杂,但它仍然可行。

在这种情况下,它变成了:

awk '
    FNR==1       {city = ""; mgr = ""}
    /^city=/     {gsub (/^city=/, "", $0); city = $0}
    /^manager=/  {gsub (/^manager=/, "", $0); mgr = $0}
                 {if (city!="" && mgr!=""){
                     print mgr "," city; city = ""; mgr = "";
                 }}
' *.config

这样做是为了使订单无关紧要。它将city和manager变量重置为每个文件开头的空字符串,并将它们存储在找到相关行的情况下。在每一行之后,如果两者都设置了,它将打印并清除它们。