[英]Shell script to extract 2 values from all files?
我有一个充满这样的文件的目录:
[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在自己的行上返回整行,我只想在第一个=符号后面的部分。
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
字符串。
类似于约翰库格曼的答案,但使用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
您可以使用单个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变量重置为每个文件开头的空字符串,并将它们存储在找到相关行的情况下。 在每一行之后,如果两者都设置了,它将打印并清除它们。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.