根据两列选择唯一的行

cos*_*ist 8 unix awk

我一直试图找出一种方法来根据两列的值选择唯一的行.例如,这是我的文件的示例/示例:

chr1    10    12
chr1    10    12
chr1    10    11
chr1    9    12
chr2    15    20
Run Code Online (Sandbox Code Playgroud)

这就是我希望我的输出看起来像:

chr1    10    12
chr1    10    11
chr1    9    12
chr2    15    20
Run Code Online (Sandbox Code Playgroud)

我试过使用这段代码,因为我喜欢它不会弄乱我文件的顺序:

awk -F"\t" '!_[$2]++' SNP_positions.txt > SNP_positions_uniq.txt
Run Code Online (Sandbox Code Playgroud)

但是,它仅捕获一列的独特功能.有没有办法编辑它以使其适用于两列?

fed*_*qui 14

您可以完美地使用对数组元素使用多个字段的索引:

awk -F"\t" '!seen[$2, $3]++' file
Run Code Online (Sandbox Code Playgroud)

在这种情况下,我们使用$2, $3索引.这样,我们将获得元组的所有不同元素($2, $3).

  • @jaypalsingh请注意,数组索引中的`,`与print语句中的`,`不同.前者得到`SUBSEP`(默认情况下,控制字符)的值,而后者得到`OFS`(缺省是空格)的值. (2认同)