免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1615 | 回复: 9
打印 上一主题 下一主题

[文本处理] 如果根据 第二个文件的行数 来自动合并 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2018-11-13 16:21 |只看该作者 |倒序浏览
A文件

name  sex
张三    男
张三    男

B文件

工作年限  手机
5           133
11         133
5           135
7           156
8           145

A文件会自动根据B文件的行数 来填充自己行 并合并 如上 B文件是 6 行 合并后如下

name  sex  工作年限  手机
张三    男    5           133
张三    男    11         133
张三    男    5           135
张三    男    7           156
张三    男    8           145




论坛徽章:
0
2 [报告]
发表于 2018-11-13 18:55 |只看该作者
$ awk 'FILENAME==ARGV[1]{ b[++i]=$0} FILENAME==ARGV[2]{if (FNR==1){print $0,b[1]} else {if (!a[$1]){ for (i in b){{if (i!=1){print $0,b}}}}a[$1]=$1}}' b.txt a.txt


name  sex  工作年限  手机
张三    男 5           133
张三    男 11         133
张三    男 5           135
张三    男 7           156
张三    男 8           145


论坛徽章:
0
3 [报告]
发表于 2018-11-14 09:58 |只看该作者
本帖最后由 xin2v 于 2018-11-14 10:00 编辑

网络又问题 发重复了

论坛徽章:
0
4 [报告]
发表于 2018-11-14 09:59 |只看该作者
本帖最后由 xin2v 于 2018-11-14 10:00 编辑

网络又问题 发重复了

论坛徽章:
0
5 [报告]
发表于 2018-11-14 09:59 |只看该作者
回复 2# csccyab

[root@sftp02 tmp]# cat a.txt
Common App
19933400 FY
19933400 FY
[root@sftp02 tmp]# cat b.txt
Common App
19933400 FY
20478740 FY
17580349 FY
20224366 FY
20349770 FY
21604135 FY
21642087 FY
21763159 FY
21819993 FY
[root@sftp02 tmp]# awk 'FILENAME==ARGV[1]{ b[++i]=$0} FILENAME==ARGV[2]{if (FNR==1){print $0,b[1]} else {if (!a[$1]){ for (i in b){{if (i!=1){print $0,b}}}}a[$1]=$1}}' b.txt a.txt
Common App Common App
awk: cmd. line:1: (FILENAME=a.txt FNR=2) fatal: attempt to use array `b' in a scalar context

论坛徽章:
0
6 [报告]
发表于 2018-11-14 10:22 |只看该作者
$ awk 'FILENAME==ARGV[1]{ b[++i]=$0; count++} FILENAME==ARGV[2]{if (FNR==1){print $0,b[1]} else {if (!a[$1]){ for (i=2;i<=count;i++){print $0,b}}a[$1]=$1}}' b.txt a.txt
Common App Common App
19933400 FY 19933400 FY
19933400 FY 20478740 FY
19933400 FY 17580349 FY
19933400 FY 20224366 FY
19933400 FY 20349770 FY
19933400 FY 21604135 FY
19933400 FY 21642087 FY
19933400 FY 21763159 FY
19933400 FY 21819993 FY

论坛徽章:
25
程序设计版块每日发帖之星
日期:2016-05-03 06:20:0015-16赛季CBA联赛之八一
日期:2018-07-05 10:34:09黑曼巴
日期:2018-07-06 15:19:5015-16赛季CBA联赛之佛山
日期:2018-08-03 13:19:3315-16赛季CBA联赛之山西
日期:2018-08-07 19:46:2315-16赛季CBA联赛之广夏
日期:2018-08-08 19:31:5015-16赛季CBA联赛之青岛
日期:2018-11-26 15:21:5015-16赛季CBA联赛之上海
日期:2018-12-11 09:45:3219周年集字徽章-年
日期:2020-04-18 23:54:5215-16赛季CBA联赛之深圳
日期:2020-04-19 21:40:19黑曼巴
日期:2022-04-03 17:55:1315-16赛季CBA联赛之八一
日期:2018-07-03 16:56:46
7 [报告]
发表于 2018-11-14 10:24 |只看该作者
回复 1# xin2v


  1. awk 'FILENAME==ARGV[1]{a[NR]=$0;next}FNR==1{b=length(a);c=a[b]}{print (FNR>b)?c" "$0:a[FNR]" "$0}' A B
复制代码

论坛徽章:
0
8 [报告]
发表于 2018-11-14 10:31 |只看该作者
回复 6# csccyab

[root@sftp02 tmp]# cat a.txt
Common App
19933400 FY
19933400 FY
[root@sftp02 tmp]# cat b.txt
Common App
19933400 FY
20478740 FY
17580349 FY
20224366 FY
20349770 FY
21604135 FY
21642087 FY
21763159 FY
21819993 FY


[root@sftp02 tmp]# awk 'FILENAME==ARGV[1]{ b[++i]=$0; count++} FILENAME==ARGV[2]{if (FNR==1){print $0,b[1]} else {if (!a[$1]){ for (i=2;i<=count;i++){print $0,b}}a[$1]=$1}}' b.txt a.txt
Common App Common App
awk: cmd. line:1: (FILENAME=a.txt FNR=2) fatal: attempt to use array `b' in a scalar context
[root@sftp02 tmp]#

论坛徽章:
0
9 [报告]
发表于 2018-11-14 10:31 |只看该作者
回复 6# csccyab

[root@sftp02 tmp]# cat a.txt
Common App
19933400 FY
19933400 FY
[root@sftp02 tmp]# cat b.txt
Common App
19933400 FY
20478740 FY
17580349 FY
20224366 FY
20349770 FY
21604135 FY
21642087 FY
21763159 FY
21819993 FY


[root@sftp02 tmp]# awk 'FILENAME==ARGV[1]{ b[++i]=$0; count++} FILENAME==ARGV[2]{if (FNR==1){print $0,b[1]} else {if (!a[$1]){ for (i=2;i<=count;i++){print $0,b}}a[$1]=$1}}' b.txt a.txt
Common App Common App
awk: cmd. line:1: (FILENAME=a.txt FNR=2) fatal: attempt to use array `b' in a scalar context
[root@sftp02 tmp]#

论坛徽章:
0
10 [报告]
发表于 2018-11-14 10:34 |只看该作者
回复 7# wh7211

测试 OK 感谢
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP