免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1004 | 回复: 3

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

论坛徽章:
1
15-16赛季CBA联赛之山东
日期:2016-03-02 14:33:02
发表于 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
发表于 2016-07-06 12:01 |显示全部楼层
ubuntu@ubuntu1:/tmp$ cat a.sh
#!/bin/bash
declare -A data A
while read num name date sign
do
        data[$sign]=$date
        A[$sign]=$name
done < <(sed -n '2,$p' A)
echo -e "sign\tname1\tname2\tdate1\tdate2\ttimelag"
while read num name data sign
do
        echo -e "$sign\t${A[$sign]}\t$name\t${data[$sign]}\t$data\t$(expr \( $(date -d  $data +%s) - $(date -d ${data[$sign]} +%s) \) / 3600 / 24 )"
done < <(sed -n '2,$p' B)
ubuntu@ubuntu1:/tmp$ ./a.sh
sign    name1   name2   date1   date2   timelag
【京东】        李四    tom     2015-02-02      2015-02-22      20
【淘宝】        张三    jine    2015-01-01      2015-01-23      22
【叮当】        王五    jine    2015-03-03      2015-05-25      83
【叮当】        王五    jack    2015-03-03      2015-03-23      20
【京东】        李四    marry   2015-02-02      2015-04-14      71

论坛徽章:
130
技术图书徽章
日期: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
发表于 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
发表于 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# 寂寞卜孤单


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

本版积分规则 发表回复

SACC2019中国系统架构师大会

【数字转型 架构演进】SACC2019中国系统架构师大会
2019年10月31日~11月2日第11届中国系统架构师大会(SACC2019)将在北京隆重召开。四大主线并行的演讲模式,1个主会场、20个技术专场、超千人参与的会议规模,100+来自互联网、金融、制造业、电商等领域的嘉宾阵容,将为广大参会者提供一场最具价值的技术交流盛会。




----------------------------------------

大会官网>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP