免费注册 查看新帖 |

ChinaUnix.net

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

[文本处理] 对于批量timestamp的处理 [复制链接]

论坛徽章:
0
发表于 2019-03-11 04:12 |显示全部楼层
文本如下:# cat file_name

SET timestamp=1552234561;
update car_biz_coupons
# Time: 190311  0:16:04
# User@Host: sqhc_rentcar[sqhc_rentcar] @  []  Id: 396894071
# Schema: rentcar  Last_errno: 0  Killed: 0
# Query_time: 0.471732  Lock_time: 0.000044  Rows_sent: 0  Rows_examined: 179576  Rows_affected: 1000
# Bytes_sent: 60
SET timestamp=1552234564;
update car_biz_coupons set ;
# Time: 190311  0:16:06
# User@Host: sqhc_rentcar[sqhc_rentcar] @  []  Id: 396894071
# Schema: rentcar  Last_errno: 0  Killed: 0
# Query_time: 0.482832  Lock_time: 0.000042  Rows_sent: 0  Rows_examined: 180680  Rows_affected: 1000
# Bytes_sent: 60
SET timestamp=1552234566;
update car_biz_coupons set status;
# Time: 190311  0:16:09
# User@Host: sqhc_rentcar[sqhc_rentcar] @  []  Id: 396894071
# Schema: rentcar  Last_errno: 0  Killed: 0
# Query_time: 0.485536  Lock_
# Bytes_sent: 60



大家都知道,对于UNIX timestamp使用date -d @1552234566  "+%Y-%m-%d %l:%M"即可转换,
EG:
  # date -d @1552234566  "+%Y-%m-%d %l:%M"
  2019-03-11 12:16

但是想批量转换,将上述文本的每一行遇到的”SET timestamp=xxxxx“都能自动转换为标准时间格式,使用sed或者awk,我尝试了sed '/SET timestamp=\([0-9]\+\).*{/s/\1/111/g}' file_name,这个方法不行,求教大家,谢谢啦!

论坛徽章:
2
2016科比退役纪念章
日期:2018-10-24 08:24:0115-16赛季CBA联赛之北控
日期:2019-03-12 14:34:56
发表于 2019-03-11 09:07 |显示全部楼层
试试是不是你要的效果,
  1. awk -F= '/SET timestamp/{time=substr($2,1,length($2)-1);cmdstr=sprintf("date -d @%s \"+%%Y-%%m-%%d %%l:%%M\"",time);system(cmdstr)} !/SET timestamp/{print $0}' file.txt
复制代码

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-10-11 06:20:0015-16赛季CBA联赛之山东
日期:2016-05-28 18:18:5615-16赛季CBA联赛之新疆
日期:2017-04-12 22:55:4715-16赛季CBA联赛之青岛
日期:2017-06-26 18:30:0315-16赛季CBA联赛之四川
日期:2017-09-04 12:27:0315-16赛季CBA联赛之福建
日期:2018-02-09 14:28:3315-16赛季CBA联赛之同曦
日期:2018-04-17 12:43:3415-16赛季CBA联赛之浙江
日期:2018-07-14 13:27:4015-16赛季CBA联赛之吉林
日期:2018-09-13 15:48:2915-16赛季CBA联赛之新疆
日期:2016-05-07 05:05:3215-16赛季CBA联赛之八一
日期:2016-03-14 12:32:06程序设计版块每日发帖之星
日期:2015-12-12 06:20:00
发表于 2019-03-11 09:15 |显示全部楼层
  1. awk -F '=' '/timestamp/{gsub(/;/,"",$0);"date -d @\""$2"\" +\"%F %R\""| getline a; print a}!/timestamp/' file
复制代码

论坛徽章:
0
发表于 2019-03-11 09:42 |显示全部楼层
回复 3# baby_神

语句最后的,!/timestamp/ 这个没看明白呢,其他看明白了,还请 baby_神 解答一下。谢谢

论坛徽章:
20
程序设计版块每日发帖之星
日期:2015-10-11 06:20:0015-16赛季CBA联赛之山东
日期:2016-05-28 18:18:5615-16赛季CBA联赛之新疆
日期:2017-04-12 22:55:4715-16赛季CBA联赛之青岛
日期:2017-06-26 18:30:0315-16赛季CBA联赛之四川
日期:2017-09-04 12:27:0315-16赛季CBA联赛之福建
日期:2018-02-09 14:28:3315-16赛季CBA联赛之同曦
日期:2018-04-17 12:43:3415-16赛季CBA联赛之浙江
日期:2018-07-14 13:27:4015-16赛季CBA联赛之吉林
日期:2018-09-13 15:48:2915-16赛季CBA联赛之新疆
日期:2016-05-07 05:05:3215-16赛季CBA联赛之八一
日期:2016-03-14 12:32:06程序设计版块每日发帖之星
日期:2015-12-12 06:20:00
发表于 2019-03-11 10:33 |显示全部楼层
回复 4# xiaochuanjiejie

想当于 !/timestamp/{print $0}, 只不过是把后面省略了

论坛徽章:
0
发表于 2019-03-11 15:15 |显示全部楼层
回复 1# xiaochuanjiejie

  1. sed -r 's/SET timestamp=([0-9]+);/date -d @\1 "+%F %T"/e'
复制代码

论坛徽章:
0
发表于 2019-03-12 14:12 |显示全部楼层
回复 5# baby_神

感叹号“!” 代表啥意思呢,请问。

论坛徽章:
0
发表于 2019-03-12 14:14 |显示全部楼层
回复 6# jzsjm1002

这个牛皮,简洁明了

论坛徽章:
28
ChinaUnix元老
日期:2015-02-02 08:55:392017金鸡报晓
日期:2017-01-10 15:13:29CU十四周年纪念徽章
日期:2018-08-29 22:12:2715-16赛季CBA联赛之深圳
日期:2018-09-20 12:21:09
发表于 2019-03-14 13:32 |显示全部楼层
回复 7# xiaochuanjiejie


感叹号表示“非”
也就是不包含timestamp字符串的行,直接输出。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

基于案例的 SQL 优化实战训练营

讲师:中电福富特级专家梁敬彬,参与本次课程培训,你将收获:
1. 能编写出较为高效的 SQL;
2. 能解决70%以上的数据库常见优化问题;
3. 能得到老师提供的高效的相关工具和解决方案;
4. 能举一反三,收获不仅仅是 SQL 优化。
现在购票享受8.8折优惠!
----------------------------------------
优惠时间:2019年3月20日前

大会官网>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP