RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1279375
Accepted
alex2020
alex2020
Asked:2022-05-08 00:39:07 +0000 UTC2022-05-08 00:39:07 +0000 UTC 2022-05-08 00:39:07 +0000 UTC

使用 awk、perl 或另一种单线法减去字符串中的时间

  • 772

你能告诉我如何使用单线解决以下问题吗?

目标是从当前行的第一列中减去前一行的第一列的值,并将其放在当前行之前。

有一个文件,如:

$ cat blabla 
13:06:27.578195 blablabla
13:06:27.578243 bla bla
13:06:27.578271 bla
13:06:27.578337 zzz
13:06:27.578372 zzz zzz zzz
13:06:27.578372 zzz zzz zzz
13:07:02.224100 aaa bbb ccc

有必要在一行中使用任何命令来获取表单的输出:

0 13:06:27.578195 blablabla
0.000048 13:06:27.578243 bla bla
0.000028 13:06:27.578271 bla
0.000066 13:06:27.578337 zzz
0.000035 13:06:27.578372 zzz zzz zzz
34,645728 13:07:02.224100 aaa bbb ccc

似乎这可以用 来完成awk,但我没有成功。

shell
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. Best Answer
    extrn
    2022-05-08T16:25:01Z2022-05-08T16:25:01Z

    并非没有缺陷,但仍然是一种方式

    $ perl -ane '$c = `date +%s.%N -d $F[0]`; printf "%.6f %s", $c - ($p or $c), $_; $p = $c' < log.txt
    0.000000 13:06:27.578195 blablabla
    0.000048 13:06:27.578243 bla bla
    0.000028 13:06:27.578271 bla
    0.000066 13:06:27.578337 zzz
    0.000035 13:06:27.578372 zzz zzz zzz
    0.000000 13:06:27.578372 zzz zzz zzz
    34.645728 13:07:02.224100 aaa bbb ccc
    

    请记住,在一天的边界,转变将变成负面的。

    • 1
  2. aleksandr barakin
    2022-05-08T18:08:50Z2022-05-08T18:08:50Z

    例如,使用gnu/awk程序。

    我们根据分隔符将第一个单词分成几部分:,将分钟-小时转换为秒(依次乘以 60)。

    如果接收到的值小于前一个值,我们假设这是新的一天,并从前一个值中减去一天中的秒数。

    awk 'BEGIN{ p = 0 }
    {
      split($1, a, ":");
      s = 0;
      for (i = 1; i <= length(a); i++) {
        s = s * 60 + a[i]
      };
      if (p == 0) {
        printf "0 "
      } else {
        if (p > s) {
          p = p - 60 * 60 * 24;
        }
        printf "%.6f ", s - p
      };
      p = s;
      print $0
    }'
    

    从数据集中:

    13:06:27.578195 blablabla
    13:06:27.578243 bla bla
    13:06:27.578271 bla
    13:06:27.578337 zzz
    13:06:27.578372 zzz zzz zzz
    13:06:27.578372 zzz zzz zzz
    13:07:02.224100 aaa bbb ccc
    01:07:02.224109 новый день
    

    结果是这样的:

    0 13:06:27.578195 blablabla
    0.000048 13:06:27.578243 bla bla
    0.000028 13:06:27.578271 bla
    0.000066 13:06:27.578337 zzz
    0.000035 13:06:27.578372 zzz zzz zzz
    0.000000 13:06:27.578372 zzz zzz zzz
    34.645728 13:07:02.224100 aaa bbb ccc
    43200.000009 01:07:02.224109 новый день
    

    要获得单行符,只需删除所有空格(printf 函数参数除外)和换行符:

    awk 'BEGIN{p=0}{split($1,a,":");s=0;for(i=1;i<=length(a);i++){s=s*60+a[i]};if(p==0){printf"0 "}else{if(p>s){p=p-60*60*24;}printf"%.6f ",s-p};p=s;print$0}'
    
    • 0

相关问题

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    表格填充不起作用

    • 2 个回答
  • Marko Smith

    提示 50/50,有两个,其中一个是正确的

    • 1 个回答
  • Marko Smith

    在 PyQt5 中停止进程

    • 1 个回答
  • Marko Smith

    我的脚本不工作

    • 1 个回答
  • Marko Smith

    在文本文件中写入和读取列表

    • 2 个回答
  • Marko Smith

    如何像屏幕截图中那样并排排列这些块?

    • 1 个回答
  • Marko Smith

    确定文本文件中每一行的字符数

    • 2 个回答
  • Marko Smith

    将接口对象传递给 JAVA 构造函数

    • 1 个回答
  • Marko Smith

    正确更新数据库中的数据

    • 1 个回答
  • Marko Smith

    Python解析不是css

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5