join 命令

join 命令用于将两个文件中,指定栏位内容相同的行连接起来。

找出两个文件中,指定栏位内容相同的行,并加以合并,再输出到标准输出设备。

语法

join [-i][-a<1或2>][-e<字符串>][-o<格式>][-t<字符>][-v<1或2>][-1<栏位>][-2<栏位>][--help][--version][文件1][文件2]


选项

  • -a<1 或 2> 除了显示原来的输出内容之外,还显示指令文件中没有相同栏位的行。
  • -e<字符串> 若[文件 1]与[文件 2]中找不到指定的栏位,则在输出中填入选项中的字符串。
  • -i 或--igore-case 比较栏位内容时,忽略大小写的差异。
  • -o<格式> 按照指定的格式来显示结果。
  • -t<字符> 使用栏位的分隔字符。
  • -v<1 或 2> 跟-a 相同,但是只显示文件中没有相同栏位的行。
  • -1<栏位> 连接[文件 1]指定的栏位。
  • -2<栏位> 连接[文件 2]指定的栏位。
  • --help 显示帮助。
  • --version 显示版本信息。

实例

连接两个文件。

为了清楚地了解 join 命令,首先通过 cat 命令显示文件 testfile_1 和

testfile_2 的内容。

然后以默认的方式比较两个文件,将两个文件中指定字段的内容相同的行连接起来,在终端中输入命令:

join testfile_1 testfile_2


首先查看 testfile_1、testfile_2 中的文件内容:

testfile_1 #testfile_1文件中的内容

Hello 95 #例如,本例中第一列为姓名,第二列为数额

Linux 85

test 30

cmd@hdd-desktop:~$ cat testfile_2 #testfile_2文件中的内容

Hello 2005 #例如,本例中第一列为姓名,第二列为年份

Linux 2009

test 2006


然后使用 join 命令,将两个文件连接,结果如下:

$ join testfile_1 testfile_2 #连接testfile_1、testfile_2中的内容

Hello 95 2005 #连接后显示的内容

Linux 85 2009

test 30 2006


文件 1 与文件 2 的位置对输出到标准输出的结果是有影响的。例如将命令中的两个文件互换,即输入如下命令:

join testfile_2 testfile_1

最终在标准输出的输出结果将发生变化,如下所示:

$ join testfile_2 testfile_1 #改变文件顺序连接两个文件

Hello 2005 95 #连接后显示的内容

Linux 2009 85

test 2006 30