[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

gawk如何将两个文件中的内容打印出来

由于工作需要,需将要两个文本中的两列的数据打印在一行上显示出来,该如何实现呢?

文件1内容:
aaa|111|123
bbb|222|123
ccc|333|123

文件2的内容
hhh|111|123
iii|222|123
jjj|333|123

通过gawk实现这样的输出

aaa|hhh
bbb|iii
ccc|jjj

导入到excel,删除不要的即可
目的,学习批处理

TOP

  1. gawk -F "|" "NR==FNR{a[FNR]=$1}NR>FNR{print a[FNR]\""|\""$1}" 1.txt 2.txt > 3.txt
复制代码
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

本帖最后由 shootman2 于 2018-8-19 22:03 编辑

回复 3# Batcher


     Batcher大神!请收下我的膝盖。。。
     昨晚通宵搞到4点,仍然没有解决问题!!!您这一指点一下就解决问题了。。。

TOP

回复 3# Batcher


    我理解了一下,这代码的原理是,在处理第一个文件的时候,先将$1字段的数据写入到一个数组中,然后在处理第二个文件时,
    将数组和第二个文件的$1一并打印。

    是这个思路呗?那我想问下,如果是有三个文件,要实现一楼的需求,该怎么实现呢?貌似好像没有另外一个FNR来标示正在处理第三个文件啊!

TOP

回复 5# shootman2

办法肯定不只一种,awk 有个内建变量 FILENAME 了解一下?

TOP

回复 5# shootman2
  1. gawk "ARGIND==1{...}ARGIND==2{...}ARGIND==3{...}" 1.txt 2.txt 3.txt
复制代码
我帮忙写的代码不需要付钱。如果一定要给,请在微信群或QQ群发给大家吧。
【微信公众号、微信群、QQ群】http://bbs.bathome.net/thread-3473-1-1.html
【支持批处理之家,加入VIP会员!】http://bbs.bathome.net/thread-67716-1-1.html

TOP

回复 7# Batcher


    已经按照大神您的指点完成了工作任务,再次感谢!!!

TOP

返回列表