免费注册 查看新帖 |

Chinaunix

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

请教个文本处理问题 [复制链接]

论坛徽章:
1
寅虎
日期:2014-11-30 21:25:54
31 [报告]
发表于 2009-03-09 21:23 |只看该作者
最近刚学的awk 太强大了 我写了一个条件简单的 请大家多指教
[ann@gutsy shell]$ ./ss.awk e
   99  100    0    0    0
   99    0  111  110    0
   99    1  111    0    0
   99  111   66  100   44
  100    0  111    0    0
[ann@gutsy shell]$ cat !!
cat ./ss.awk e
#!/usr/bin/awk -f

BEGIN {
        FS = "&"
        max = 0
}

{
        for(i = 2; i <= NF; i++) {
                split($i, key, "=")
                data[NR, key[1]] = key[2]
        }
        max = (key[1] > max) ? key[1] : max
}

END{
        for(i = 1; i <= NR; i++)
        {
                for(j = 1; j <= max; j++)
                        printf "%5d", data[i, j]
                printf "\n"
        }
}
&1=99&2=100
&1=99&3=111&4=110
&1=99&2=1&3=111
&1=99&2=111&3=66&4=100&5=44
&1=100&3=111

[ 本帖最后由 vbs100 于 2009-3-9 22:02 编辑 ]

论坛徽章:
0
32 [报告]
发表于 2009-03-10 14:25 |只看该作者
awk -F"&" '{printf $1" "
                   for(i=2;i<=NF;i++)
                   {
                        split($i,a,"=")
                        b[a[1]]=a[2]
                   }
                   for(m=1;m<=5;m++)
                   {
                        if(b[m])
                           printf b[m]" "
                        else
                           printf 0" "
                        delete b[m]
                   }
                   print ""
                   }' file
50万条数据类似数据:
60.191.60.0  19:13:24.661 &1=99&2=100
202.96.64.68  19:13:24.661 &1=99&2=1&3=111
实测40秒完成
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP