免费注册 查看新帖 |

Chinaunix

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

[日期时间] 请教日期转换成秒的问题 [复制链接]

论坛徽章:
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 13:38 |显示全部楼层
有两个文件:
A
  1. 1        张三        2015-01-01        【淘宝】
  2. 2        李四        2015-02-02        【京东】
  3. 3        王五        2015-03-03        【叮当】
复制代码
B
  1. 4        tom        2015-02-22        【京东】
  2. 5        jine        2015-01-23        【淘宝】
  3. 6        jine        2015-05-25        【叮当】
  4. 7        jack        2015-03-23        【叮当】
  5. 8        marry        2015-04-14        【京东】
复制代码
按如下代码运行:
  1. awk 'BEGIN{
  2.         while(getline <"A") {
  3.                 col3[$4] = $3
  4.                 cmd = "date  -d " col3[$4] " +%s"
  5.                 cmd | getline sec2
  6.                 print col3[$4] "===>" sec2
  7.         }
  8. }{
  9.                 cmd = "date  -d " col3[$4] " +%s"
  10.                 cmd | getline sec2
  11.                 print col3[$4] "=========>" sec2       
  12. }' B
复制代码
结果:红色部分结果不对。。。。。。。。
2015-01-01===>1420041600
2015-02-02===>1422806400
2015-03-03===>1425312000
2015-02-02=========>1425312000
2015-01-01=========>1425312000
2015-03-03=========>1425312000
2015-03-03=========>1425312000
2015-02-02=========>1425312000


论坛徽章:
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
发表于 2016-07-06 13:42 |显示全部楼层
本帖最后由 jason680 于 2016-07-06 13:46 编辑

回复 1# liion631818

Would you like to use "mktime" function in awk

$ echo "2015-02-02" | awk '{gsub("-"," ",$1);print mktime($1" 0 0 0")}'
1422806400


Note: you have to use "close(cmd)" in your awk

论坛徽章:
16
IT运维版块每日发帖之星
日期:2015-08-24 06:20:00综合交流区版块每日发帖之星
日期:2015-10-14 06:20:00IT运维版块每日发帖之星
日期:2015-10-25 06:20:00IT运维版块每日发帖之星
日期:2015-11-06 06:20:00IT运维版块每日发帖之星
日期:2015-12-10 06:20:00平安夜徽章
日期:2015-12-26 00:06:302016猴年福章徽章
日期:2016-02-18 15:30:34IT运维版块每日发帖之星
日期:2016-04-15 06:20:00IT运维版块每日发帖之星
日期:2016-05-21 06:20:00综合交流区版块每日发帖之星
日期:2016-08-16 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-14 06:20:00
发表于 2016-07-06 13:50 |显示全部楼层
gawk有自带的时间函数,楼上已经写了啊。

论坛徽章:
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 13:51 |显示全部楼层
回复 2# jason680


    多谢,确实加了close就可以了,man awk也有这个说明。

论坛徽章:
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 13:53 |显示全部楼层
回复 3# expert1


    嗯,只是我用的版本不支持mktime。cmd | getline的用法也不知道调用close。
多谢!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP