我想知道在awk调用中是否有创建awk对象的方法。我需要构建一个键/值映射,并在awk调用中使用它。更多的细节,我有一个地图连接一些标签与一个独特的标识(例如。"ID1002",“外部隔间”)。我想使用这个映射从另一个表中识别一组唯一的ids。下面是我在想的事情:
awk 'BEGIN{map=system(awk '{m[$1]=$2}' first.csv)}{print map[$1]}' second.csv 显然,这是行不通的,我在想,如果不构建awk脚本,我怎么能做到这样的事情呢?
发布于 2015-10-27 14:36:37
在awk中这样做的常见方法是:
$ awk 'NR==FNR{m[$1]=$2;next}{print m[$1]}' first.csv second.csv解释
NR是一个特殊的变量,在每次读取记录时都会递增。FNR类似于NR,但是每次读取新文件都会重置它。next指示awk停止对当前记录的执行,并获取下一个记录。在设置了定义之后,您可以将脚本读为:
NR==FNR # Conditional that is only true when reading the first file
{m[$1]=$2;next} # Create a map and move on to the next line
{print m[$1]} # Using next in the first block means this only runs on the second file https://stackoverflow.com/questions/33370549
复制相似问题