awk在另一个文件中搜索一个字段

时间:2011-05-11 00:56:16

标签: awk

我需要从第二个文件中的一个文件中搜索字段。想知道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,在第二行中搜索每一行并构建输出。

2 个答案:

答案 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中每个标记的文件。