免费注册 查看新帖 |

Chinaunix

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

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

论坛徽章:
0
跳转到指定楼层
1 [收藏(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,这个方法不行,求教大家,谢谢啦!

论坛徽章:
8
2016科比退役纪念章
日期:2018-10-24 08:24:0115-16赛季CBA联赛之北控
日期:2019-03-12 14:34:562016科比退役纪念章
日期:2019-04-01 10:33:0915-16赛季CBA联赛之山东
日期:2019-04-17 12:46:3215-16赛季CBA联赛之广夏
日期:2019-05-09 16:40:4015-16赛季CBA联赛之广夏
日期:2019-10-10 15:33:4015-16赛季CBA联赛之辽宁
日期:2019-10-15 08:37:0615-16赛季CBA联赛之北控
日期:2021-03-30 15:53:34
2 [报告]
发表于 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
3 [报告]
发表于 2019-03-11 09:15 |只看该作者
  1. awk -F '=' '/timestamp/{gsub(/;/,"",$0);"date -d @\""$2"\" +\"%F %R\""| getline a; print a}!/timestamp/' file
复制代码

论坛徽章:
0
4 [报告]
发表于 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
5 [报告]
发表于 2019-03-11 10:33 |只看该作者
回复 4# xiaochuanjiejie

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

论坛徽章:
0
6 [报告]
发表于 2019-03-11 15:15 |只看该作者
回复 1# xiaochuanjiejie

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

论坛徽章:
0
7 [报告]
发表于 2019-03-12 14:12 |只看该作者
回复 5# baby_神

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

论坛徽章:
0
8 [报告]
发表于 2019-03-12 14:14 |只看该作者
回复 6# jzsjm1002

这个牛皮,简洁明了

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
9 [报告]
发表于 2019-03-14 13:32 |只看该作者
回复 7# xiaochuanjiejie


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

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP