免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: filwy
打印 上一主题 下一主题

请教一个较复杂的时间比较问题 [复制链接]

论坛徽章:
0
11 [报告]
发表于 2010-04-13 09:24 |只看该作者
try
blackold 发表于 2010-04-13 00:06



    学习了。
将第一列出现超过3次的过滤掉
  1. awk -F '[ &]'
  2. 'BEGIN{d=strftime("%Y-%m-%d")}
  3. NR==FNR
  4. {r[$1]++;
  5. if(!m[$1]||m[$1]>$4)
  6.     m[$1]=$4;
  7. next
  8. }
  9. !((r[$1] > 3) || (r[$1]==3&&m[$1]==$4))
  10. {if($4>d)
  11.     print>"fileB";
  12. else
  13.     print>"fileA"
  14. }'
  15. urfile urfile
复制代码

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
12 [报告]
发表于 2010-04-13 09:29 |只看该作者
回复 11# crowsy001


    嗯,考虑得比较全面。

论坛徽章:
0
13 [报告]
发表于 2010-04-13 11:58 |只看该作者
我也来个。不过比较难看 哎先实现吧


BEGIN{
  FS = "&"
  time=strftime("%Y-%m-%d %H:%M:%S")  
}
{
  record[NR]=$0
  ind[$1]++

}
END{
    for (i in ind){
      
      if (ind[i] >= 3){
         tmp=i
         for (j=1;j<=NR;j++){
           if (record[j] ~ tmp){
              split(record[j],array,"&")
              if (time < array[3]){
                   print record[j] >> "a.txt"
              }else{
                   value[m]=record[j]
                   m++  
              }
            
          }

       }
        if (value[0]>value[1]){

            print value[0] >> "b.txt"
          }else{
            print value[1] >> "b.txt"
          }
     }
     
}
}

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
14 [报告]
发表于 2010-04-13 12:01 |只看该作者
回复 13# iori809


   一看就知道是专业程序员。

论坛徽章:
0
15 [报告]
发表于 2010-04-13 13:14 |只看该作者
回复 1# filwy


    太难的东西先别看,从简单的学起。飘过.........

论坛徽章:
0
16 [报告]
发表于 2010-04-14 08:54 |只看该作者
本帖最后由 springwind426 于 2010-04-14 09:03 编辑

  1. 我的思路是先排序(按照第一和第三字段排序),然后读取信息,只保存三行信息,当第三行时进行判断并处理

  2. test.awk

  3. BEGIN{i=0;FS="&";today=strftime("%Y-%m-%d 23:59:59")}
  4. {
  5.         i++
  6.         a[i]=$0
  7.         b[i]=$1
  8.         c[i]=$3
  9. }
  10. i==3{
  11.         if (b[1]==b[2] && b[2]==b[3])
  12.         {
  13.                 i=0;
  14.                 f=(c[2]>today)?"fileA":"fileB"
  15.                 print a[2] >> f
  16.                 f=(c[3]>today)?"fileA":"fileB"
  17.                 print a[3] >> f
  18.         }
  19.         else if(b[2]==b[3])
  20.         {
  21.                 f=(c[1]>today)?"fileA":"fileB"
  22.                 print a[1] >> f
  23.                 a[1]=a[2];
  24.                 b[1]=b[2];
  25.                 c[1]=c[2];
  26.                 a[2]=a[3];
  27.                 b[2]=b[3];
  28.                 c[2]=c[3];
  29.                 i=2
  30.         }
  31.         else
  32.         {
  33.                 f=(c[1]>today)?"fileA":"fileB"
  34.                 print a[1] >> f
  35.                 f=(c[2]>today)?"fileA":"fileB"
  36.                 print a[2] >> f
  37.                 i=1
  38.                 a[1]=a[3];
  39.                 b[1]=b[3];
  40.                 c[1]=c[3];
  41.         }
  42. }
  43. END{
  44.         if(i<3){
  45.                 f=(c[1]>today)?"fileA":"fileB"
  46.                 print a[1] >> f
  47.         }
  48.         if(i==2){
  49.                 f=(c[2]>today)?"fileA":"fileB"
  50.                 print a[2] >> f
  51.         }
  52. }

  53. 解释:
  54. 当三行的第一字段都相同的时候,只输出第二和第三行
  55. 当第二和第三行的第一字段相同时,表明第一行是孤行,则输出,同时把第二和第三行前移
  56. 否则,第一行、第二行都是孤行,输出,第三行移到第一行

  57. sort -t'&' -k1,1 -k3,3  数据文件 | awk -f test.awk

复制代码

论坛徽章:
0
17 [报告]
发表于 2010-04-14 09:17 |只看该作者
本帖最后由 springwind426 于 2010-04-14 09:22 编辑

  1. 思路2:

  2. 按照第一字段排序,第三字段逆排序,然后取信息,第一字段出现3次及三次以上的都不输出,其他的按照需求输出

  3. sort -t'&' -k1,1 -k3,3r 数据文件 | awk -F'&' -v today="$(date +'%Y-%m-%d %H:%M:%S')" '++a[$1]<3{file=($3>today)?"fileA":"fileB";print >>file}'

复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP