鱼C论坛

 找回密码
 立即注册
查看: 967|回复: 2

[已解决]linux基本文件操作

[复制链接]
发表于 2023-4-13 16:25:39 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
若A文件的第4列有与B文件的第1列字符相同的字符,则输出A文件的1,2,3,4列与B文件的第5列
最佳答案
2023-4-13 16:33:14
要实现这个功能,你可以使用Linux命令行工具awk。首先,确保你的A文件和B文件是使用空格或制表符分隔的列。假设A文件名为fileA.txt,B文件名为fileB.txt,我们可以使用以下命令:
awk 'NR==FNR {a[$1]=$5; next} $4 in a {print $1, $2, $3, $4, a[$4]}' fileB.txt fileA.txt > output.txt

解释:

  • NR==FNR:当记录数(NR)等于文件记录数(FNR)时,即仅处理第一个文件(fileB.txt)。
  • {a[$1]=$5; next}:将第一个文件的第1列作为数组a的键,第5列作为对应的值。next表示处理下一行。
  • $4 in a:当第二个文件(fileA.txt)的第4列值在数组a中存在时,执行后面的代码块。
  • {print $1, $2, $3, $4, a[$4]}:打印第二个文件的1,2,3,4列,以及数组a中以第4列值为键的对应值(即B文件的第5列)。
  • > output.txt:将结果输出到名为output.txt的文件中。


运行这个命令后,你会得到一个名为output.txt的文件,包含满足条件的A文件的1,2,3,4列与B文件的第5列。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-4-13 16:33:14 | 显示全部楼层    本楼为最佳答案   
要实现这个功能,你可以使用Linux命令行工具awk。首先,确保你的A文件和B文件是使用空格或制表符分隔的列。假设A文件名为fileA.txt,B文件名为fileB.txt,我们可以使用以下命令:
awk 'NR==FNR {a[$1]=$5; next} $4 in a {print $1, $2, $3, $4, a[$4]}' fileB.txt fileA.txt > output.txt

解释:

  • NR==FNR:当记录数(NR)等于文件记录数(FNR)时,即仅处理第一个文件(fileB.txt)。
  • {a[$1]=$5; next}:将第一个文件的第1列作为数组a的键,第5列作为对应的值。next表示处理下一行。
  • $4 in a:当第二个文件(fileA.txt)的第4列值在数组a中存在时,执行后面的代码块。
  • {print $1, $2, $3, $4, a[$4]}:打印第二个文件的1,2,3,4列,以及数组a中以第4列值为键的对应值(即B文件的第5列)。
  • > output.txt:将结果输出到名为output.txt的文件中。


运行这个命令后,你会得到一个名为output.txt的文件,包含满足条件的A文件的1,2,3,4列与B文件的第5列。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-4-13 16:42:57 | 显示全部楼层
默认制表符分割:
awk 'NR==FNR {a[$1]=$5; next} $4 in a {print $1,$2,$3,$4,a[$4]}' B.txt A.txt
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-22 00:09

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表