我需要从第二个文件中的一个文件中搜索字段。想知道awk是否是正确的解决方案
档案1
one
two
文件2
something one
balh one
blah two
blah two
必需的输出
one ["something one", "blah one"]
two [ "blah two" , "blah two"]
我希望我可以在awk中使用awk,在第二行中搜索每一行并构建输出。
答案 0 :(得分:3)
一次awk调用就足够了
awk '
FNR == NR {
# reading file1
values[$1] = ""
next
}
{
# reading file2
for (elem in values)
if ($0 ~ elem)
if (values[elem] == "")
values[elem] = "\"" $0 "\""
else
values[elem] = values[elem] ", \"" $0 "\""
}
END {
for (elem in values)
print elem " [" values[elem] "]"
}
' file1 file2
像Ruby这样的东西可能更容易
keys = File.readlines("file1").collect {|line| line.chomp}
values = Hash.new {|h,k| h[k] = []}
File.foreach("file2") do |line|
line.chomp!
keys.each do |key|
if line.include?(key)
values[key] << line
end
end
end
values.each {|key,value| puts key + " " + value.inspect}
答案 1 :(得分:3)
如果您愿意接受稍微不同的输出以换取更简单的解决方案,那么grep就是您的工具:
grep -f file1 file2
上面的命令搜索file1中每个标记的文件。