我在以下方面需要帮助:我有一个名为file-1的文件
1
++++++^^++++
++++++++++++
+++++++++^^^
^^++++++++++
2
++++++++++++
^^^+++++^^^^
^^^^^^^+++++
+++++^^^++^+现在,我想打印出起始号与另一个名为file-2的文件中相同的部分。假设file-2包含1值,因此我需要获得以下输出:
1
++++++^^++++
++++++++++++
+++++++++^^^
^^++++++++++有人能给我提个建议吗?
发布于 2012-01-12 22:10:05
$ awk -v RS='' 'NR==FNR{split($0, a, /\n/); next}; $1 in a' file-{2,1}
1
++++++^^++++
++++++++++++
+++++++++^^^
^^++++++++++file-2包含逐行索引:
1
3
5解释:
RS=''告诉rest读取多行recordsNR==FNR awk作为一行读取file-2,所以我们应该先读取split,并将结果保存在数组recordsNR==FNR跳过awk命令,准备读取file-1$1 in a测试数组afile-{2,1}中是否有file-1的第一列我们应该先读取file-2以获得所有的索引发布于 2012-01-12 23:12:16
这可能对你有用:
sed 's|.*|/^&$/,/^$/p|' file2 | sed -nf - file1
1
++++++^^++++
++++++++++++
+++++++++^^^
^^++++++++++发布于 2012-01-13 02:07:50
使用GNU-awk,您可以尝试这样的操作-
gawk 'NR==FNR {for (i=1;i<=NF;i++) a[$i];next} ($1 in a)' RS='\n\n' file-{2,1}说明:
\n\n。我们使用循环,并在file-2中以数组的形式存储值。这将确定您要从file-1中提取哪些记录。,
file-1的第一列。如果它出现在数组中,我们打印该记录。否则我们就不会了。测试:
[jaypal:~/Temp] cat file-1
1
++++++^^++++
++++++++++++
+++++++++^^^
^^++++++++++
2
++++++++++++
^^^+++++^^^^
^^^^^^^+++++
+++++^^^++^+
[jaypal:~/Temp] cat file-2
1
3
4
[jaypal:~/Temp] gawk 'NR==FNR {for (i=1;i<=NF;i++) a[$i];next} ($1 in a)' RS='\n\n' file-{2,1}
1
++++++^^++++
++++++++++++
+++++++++^^^
^^++++++++++https://stackoverflow.com/questions/8836184
复制相似问题