免费注册 查看新帖 |

Chinaunix

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

[日期时间] 将A,B两个文件中sign相同的数据关联在一起,并计算出两个日期的时间差 [复制链接]

论坛徽章:
1
15-16赛季CBA联赛之山东
日期:2016-03-02 14:33:02
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2016-07-06 11:03 |只看该作者 |倒序浏览
A文件
Num        name1        date1                 sign
1        张三        2015-01-01        【淘宝】
2        李四        2015-02-02        【京东】
3        王五        2015-03-03        【叮当】
B文件
Num        name2        date2                 sign
4        tom        2015-02-22        【京东】
5        jine        2015-01-23        【淘宝】
6        jine        2015-05-25        【叮当】
7        jack        2015-03-23        【叮当】
8        marry        2015-04-14        【京东】
将A,B两个文件中sign相同的数据关联在一起,并计算出两个日期的时间差
C文件
  sign                name1        name2        date1                date2                timelag
【淘宝】        张三        jine        2015-01-01        2015-01-23        22
【京东】        李四        tom        2015-02-02        2015-02-22        20
【京东】        李四        marry        2015-02-02        2015-04-14        72
【叮当】        王五        jine        2015-03-03        2015-05-25        83       
【叮当】        王五        jack        2015-03-03        2015-03-23        20

求职 : 技术支持/维
论坛徽章:
0
2 [报告]
发表于 2016-07-06 12:01 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
3 [报告]
发表于 2016-07-06 12:04 |只看该作者

论坛徽章:
10
天蝎座
日期:2013-09-22 22:32:23程序设计版块每日发帖之星
日期:2016-08-07 06:20:00lufei
日期:2016-06-17 17:38:40程序设计版块每日发帖之星
日期:2016-06-12 06:20:002016科比退役纪念章
日期:2016-05-31 15:47:20CU十四周年纪念徽章
日期:2016-05-27 12:24:562015年亚洲杯之阿曼
日期:2015-05-03 21:01:352015年辞旧岁徽章
日期:2015-03-03 16:54:15天蝎座
日期:2013-10-20 21:05:24程序设计版块每日发帖之星
日期:2016-08-11 06:20:00
4 [报告]
发表于 2016-07-06 20:07 |只看该作者
  1. #!/bin/bash

  2. awk 'BEGIN{
  3.         while(getline <"A") {
  4.                 key[$4]++
  5.                 col1[$4] = $1
  6.                 col2[$4] = $2
  7.                 col3[$4] = $3
  8.         }
  9. }{
  10.         if($4 in key){
  11.                 if(NR==1)
  12.                         timelag = "timelag"
  13.                 else {
  14.                         cmd = "date  -d" $3 " +%s"
  15.                         cmd | getline sec1
  16.                         close(cmd)
  17.                         cmd = "date  -d " col3[$4] " +%s"
  18.                         cmd | getline sec2
  19.                         timelag = (sec1 - sec2) / (3600*24)
  20.                         close(cmd)
  21.                 }
  22.                
  23.                 printf "%-10s\t%-10s\t%-10s\t%-10s\t%-10s\t%s\n", $4, col2[$4], $2, col3[$4], $3, timelag
  24.         }
  25. }' B
复制代码
回复 1# 寂寞卜孤单


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

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP