1

我有两个文件。其中一个定义了一组数值对,如下所示(fileA):

 1  asm
 2  assert
 3  bio
 4  bootasm
 5  bootmain
 6  buf
 7  cat
 8  console
 9  defs
10  echo

另一个文件包含一堆值对,如下(fileB):

bio types
bio defs
bio param
bio spinlock
bio buf
bootasm asm
bootasm memlayout
bootasm mmu
bootmain types
bootmain elf
bootmain x86
bootmain memlayout
cat types
cat stat
cat user

我想编写一个脚本,用文件 A 中的相应数字替换文件 B 上的值。它是生成新文件还是更改现有文件 B 都没有关系。

有任何想法吗?谢谢

4

3 回答 3

4
awk 'NR==FNR{a[$2]=$1;next}{$1=a[$1];}1' fileA fileB

NR==FNR{a[$2]=$1;next} => 处理文件 A 时为真。形成一个关联数组,其中索引是第 2 列,第 1 列作为其值。

{$1=a[$1];} => 处理第二个文件时,将第一列替换为存储在数组中的适当值。

1 => 打印每一行。

于 2012-10-26T02:18:44.443 回答
2

这可能对您有用(GNU sed):

sed 's|^\s*\(\S*\)\s*\(.*\)$|/^\2\\>/s//\1/|' fileA | sed -f - fileB
于 2012-10-26T04:53:26.560 回答
0

请注意,如果您在 fileB 第一列中有未定义的字符串,@Guru 的解决方案将不起作用,例如:

文件B

...
name user
name system

将输出:

...
 user
 system

在这种情况下,字符串“name”将被截断。如果所有行都匹配,则可以正常工作。

于 2022-01-14T09:58:14.137 回答