两个文本文件的内部连接
- 2024-09-30 14:02:00
- admin 原创
- 166
问题描述:
希望对两个不同的文本文件执行内连接。基本上,我正在寻找 GNU join 程序的内连接等效程序。有这样的程序吗?如果没有,awk
或sed
解决方案将最有帮助,但我的首选是 Linux 命令。
这是我想要做的一个例子
文件 1:
0|Alien Registration Card LUA|Checklist Update
1|Alien Registration Card LUA|Document App Plan
2|Alien Registration Card LUA|SA Application Nbr
3|Alien Registration Card LUA|tmp_preapp-DOB
0|App - CSCE Certificate LUA|Admit Type
1|App - CSCE Certificate LUA|Alias 1
2|App - CSCE Certificate LUA|Alias 2
3|App - CSCE Certificate LUA|Alias 3
4|App - CSCE Certificate LUA|Alias 4
文件2:
Alien Registration Card LUA
结果:
0|Alien Registration Card LUA|Checklist Update
1|Alien Registration Card LUA|Document App Plan
2|Alien Registration Card LUA|SA Application Nbr
3|Alien Registration Card LUA|tmp_preapp-DOB
解决方案 1:
这是一个 awk 选项,因此您可以避免对 bash 的依赖(为了可移植性):
$ awk -F'|' 'NR==FNR{check[$0];next} $2 in check' file2 file1
这是如何运作的?
-F'|'
-- 设置字段分隔符'NR==FNR{check[$0];next}
-- 如果总记录数与文件记录数匹配(即,我们正在读取提供的第一个文件),那么我们填充一个数组并继续。$2 in check
-- 如果我们创建的数组中提到了第二个字段,则打印该行(如果没有提供任何操作,则这是默认操作)。file2 file1
—— 文件。由于NR==FNR
构造的原因,顺序很重要。
解决方案 2:
file2 不应该包含LUA
在最后吗?
如果是,您仍然可以使用join
:
join -t'|' -12 <(sort -t'|' -k2 file1) file2
解决方案 3:
看起来你只需要
grep -F -f file2 file1
解决方案 4:
你可以修改这个脚本:
cat file2 | while read line; do
grep $line file1 # or whatever you want to do with the $line variable
done
while 循环逐行读取 file2,并将该行提供给 grep 命令,该命令会在 file1 中查找该行。有一些额外的输出,可以使用 grep 选项删除。
解决方案 5:
您可以使用粘贴命令来合并文件:
paste [option] source files [>destination file]
对于你的例子来说
paste file1.txt file2.txt >result.txt
相关推荐
热门文章
项目管理软件有哪些?
- 2024年20款好用的项目管理软件推荐,项目管理提效的20个工具和技巧
- 2024年开源项目管理软件有哪些?推荐5款好用的项目管理工具
- 2024年常用的项目管理软件有哪些?推荐这10款国内外好用的项目管理工具
- 项目管理软件有哪些?推荐7款超好用的项目管理工具
- 项目管理软件有哪些最好用?推荐6款好用的项目管理工具
- 项目管理软件哪个最好用?盘点推荐5款好用的项目管理工具
- 项目管理软件有哪些,盘点推荐国内外超好用的7款项目管理工具
- 项目管理软件排行榜:2024年项目经理必备5款开源项目管理软件汇总
- 项目管理必备:盘点2024年13款好用的项目管理软件
- 2024项目管理软件排行榜(10类常用的项目管理工具全推荐)
热门标签
云禅道AD