免费注册 查看新帖 |

Chinaunix

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

[文本处理] 怎样合并文件?(第一列不确定是否完全一样) [复制链接]

论坛徽章:
2
摩羯座
日期:2014-11-03 15:28:56卯兔
日期:2015-01-04 17:20:51
1 [报告]
发表于 2014-09-25 15:08 |显示全部楼层
本帖最后由 bulletmarquis 于 2014-09-25 15:09 编辑

只输出第一列一样的~
  1. awk 'NR==FNR{a[$1]=$0;next}a[$1]{print a[$1],$2}' b a
复制代码

论坛徽章:
2
摩羯座
日期:2014-11-03 15:28:56卯兔
日期:2015-01-04 17:20:51
2 [报告]
发表于 2014-09-25 15:21 |显示全部楼层
回复 7# xunong


    比月经出现还频繁

论坛徽章:
2
摩羯座
日期:2014-11-03 15:28:56卯兔
日期:2015-01-04 17:20:51
3 [报告]
发表于 2014-09-25 15:38 |显示全部楼层
回复 9# xunong


    如果用function a(x,y)这样定义过的,那就是函数名,否则是变量名或者数组名
   如果文件名也叫a,在awk里面读取文件的时候,要用双引号引起来

论坛徽章:
2
摩羯座
日期:2014-11-03 15:28:56卯兔
日期:2015-01-04 17:20:51
4 [报告]
发表于 2014-09-25 15:53 |显示全部楼层
本帖最后由 bulletmarquis 于 2014-09-25 16:01 编辑

回复 13# xunong


join不熟

awk的话,如果不只两个文件,就不能简单的用NR==FNRorNR!=FNR来判断是在读取哪一个文件了
要用到FILENAME变量

论坛徽章:
2
摩羯座
日期:2014-11-03 15:28:56卯兔
日期:2015-01-04 17:20:51
5 [报告]
发表于 2014-09-25 16:00 |显示全部楼层
本帖最后由 bulletmarquis 于 2014-09-25 16:01 编辑

回复 13# xunong

也可以用下面的方式来做
  1. cat a
  2. a 1
  3. b 2
  4. c 3

  5. cat b
  6. a 4
  7. b 5
  8. c 6

  9. cat c
  10. a 7
  11. b 8
  12. c 9

  13. awk '!a[$1]{b[++i]=$1}{a[$1]=!a[$1]?$1" "$2:a[$1]" "$2}END{for(k=1;k<=i;k++)print a[b[k]]}' a b c
  14. a 1 4 7
  15. b 2 5 8
  16. c 3 6 9
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP