检查awk数组是否包含值

时间:2014-11-04 22:35:32

标签: arrays awk

使用Perl,您可以检查数组是否包含值

$ perl -e '@foo=(444,555,666); print 555 ~~ @foo ? "T" : "F"'
T

但是对于awk,这个类似的命令是检查数组索引而不是 值

$ awk 'BEGIN {split("444 555 666", foo); print 555 in foo ? "T" : "F"}'
F

如何使用awk检查数组是否包含特定值?

2 个答案:

答案 0 :(得分:8)

Awk noob在这里。我消化了Steven's answer并最终得到了这个希望更容易理解下面的片段。还有两个微妙的问题:

  • Awk数组实际上是一个字典。它不是["value1", "value2"],更像{0: "value1", 1: "value2"}
  • in检查密钥,并且没有内置方法来检查值。

因此,您必须将数组(实际上是字典)转换为值为键的字典。

BEGIN {

    split("value1 value2", valuesAsValues)
    # valuesAsValues = {0: "value1", 1: "value2"}

    for (i in valuesAsValues) valuesAsKeys[valuesAsValues[i]] = ""
    # valuesAsKeys = {"value1": "", "value2": ""}
}

# Now you can use `in`
($1 in valuesAsKeys) {print}

对于单行:

echo "A:B:C:D:E:F" | tr ':' '\n' | \
awk 'BEGIN{ split("A D F", parts); for (i in parts) dict[parts[i]]=""}  $1 in dict'

答案 1 :(得分:6)

基于Thor’s comment,这个功能对我有用:

function smartmatch(diamond, rough,   x, y) {
  for (x in rough) y[rough[x]]
  return diamond in y
}
BEGIN {
  split("444 555 666", z)
  print smartmatch(555, z) ? "T" : "F"
}