• 技术文章 >后端开发 >php教程

    javascript - 能帮忙写一个多行正则提取的规则吗?

    2016-06-06 20:16:28原创627

    以下是log日志,希望能够通过正则提取到各个字段的内容,任何语言的正则都可以

    =====================[2016-03-03 14:56:36]==================
    IP:    127.0.0.1
    Agent:    Dalvik/2.1.0 (Linux; U; Android 5.1.1; jacinto6evm Build/LMY48P)
    URL:    http://127.0.0.1/report?power={"charge_state":0,"battery":0.0}&location={"lat":0.0,"lng":0.0}&env={"air":{"pm25":0.0},"humidity":0.0}
    POST:    power={"charge_state":0,"battery":0.0}&location={"lat":0.0,"lng":0.0}&env={"air":{"pm25":0.0},"humidity":0.0}
    COOKIE:    C_TOKEN=98f1706e92ab-e3195b005d65c4aa7df00566be939841
    ErrorCode:    0
    Result:    {"error_code":0,"error_msg":"","data":null,"time":1456988196}
    
    
    =====================[2016-03-03 14:56:36]==================
    IP:127.0.0.1
    Agent:    Dalvik/2.1.0 (Linux; U; Android 5.1.1; jacinto6evm Build/LMY48P)
    URL:    http://127.0.0.1/report?power={"charge_state":0,"battery":0.0}&location={"lat":0.0,"lng":0.0}&env={"air":{"pm25":0.0},"humidity":0.0}
    POST:    power={"charge_state":0,"battery":0.0}&location={"lat":0.0,"lng":0.0}&env={"air":{"pm25":0.0},"humidity":0.0}
    COOKIE:    C_TOKEN=98f1706e92ab-e3195b005d65c4aa7df00566be939841
    ErrorCode:    0
    Result:    {"error_code":0,"error_msg":"","data":null,"time":1456988196}

    谢谢了,我自己写出来始终提取有问题
    这是我自己写的

    [^\[]+\[([^]]+)][^:]+:\s([^\n]+)[^:]+:\s([^\n]+)[^:]+:\s([^\n]+)[^:]+:\s([^\n]+)[^:]+:\s([^\n]+)[^:]+:\s([^\n]+)[^:]+:\s([^\n]+)[^:]+.*

    阿里云显示是正常的,但是就是提取不出来,应该是什么细节没注意到

    回复内容:

    以下是log日志,希望能够通过正则提取到各个字段的内容,任何语言的正则都可以

    =====================[2016-03-03 14:56:36]==================
    IP:    127.0.0.1
    Agent:    Dalvik/2.1.0 (Linux; U; Android 5.1.1; jacinto6evm Build/LMY48P)
    URL:    http://127.0.0.1/report?power={"charge_state":0,"battery":0.0}&location={"lat":0.0,"lng":0.0}&env={"air":{"pm25":0.0},"humidity":0.0}
    POST:    power={"charge_state":0,"battery":0.0}&location={"lat":0.0,"lng":0.0}&env={"air":{"pm25":0.0},"humidity":0.0}
    COOKIE:    C_TOKEN=98f1706e92ab-e3195b005d65c4aa7df00566be939841
    ErrorCode:    0
    Result:    {"error_code":0,"error_msg":"","data":null,"time":1456988196}
    
    
    =====================[2016-03-03 14:56:36]==================
    IP:127.0.0.1
    Agent:    Dalvik/2.1.0 (Linux; U; Android 5.1.1; jacinto6evm Build/LMY48P)
    URL:    http://127.0.0.1/report?power={"charge_state":0,"battery":0.0}&location={"lat":0.0,"lng":0.0}&env={"air":{"pm25":0.0},"humidity":0.0}
    POST:    power={"charge_state":0,"battery":0.0}&location={"lat":0.0,"lng":0.0}&env={"air":{"pm25":0.0},"humidity":0.0}
    COOKIE:    C_TOKEN=98f1706e92ab-e3195b005d65c4aa7df00566be939841
    ErrorCode:    0
    Result:    {"error_code":0,"error_msg":"","data":null,"time":1456988196}

    谢谢了,我自己写出来始终提取有问题
    这是我自己写的

    [^\[]+\[([^]]+)][^:]+:\s([^\n]+)[^:]+:\s([^\n]+)[^:]+:\s([^\n]+)[^:]+:\s([^\n]+)[^:]+:\s([^\n]+)[^:]+:\s([^\n]+)[^:]+:\s([^\n]+)[^:]+.*

    阿里云显示是正常的,但是就是提取不出来,应该是什么细节没注意到

    贴一个perl5的,对perl5不熟悉,写的不好

    if ($line =~ m/[IP|Agent|URL|POST|COOKIE|ErrorCode|Result|=+\[]+[\:]?(\d*-\d*-\d* \d*:\d*:\d*|.*)/) {
                print $1."\n";
    }

    然后是一个perl6的

    if $line ~~ /[ 
                    [\=]+\[(.*)\][\=]+     || 
                    [IP|Agent|URL|POST|COOKIE|ErrorCode|Result]\:(.*)
                ]/ {
                    say $/;
    }                            

    log 文件过大,不建议用正则表达式,你可以通过按行读取、分割字符串的方式进行处理:

    PHP 代码:

    $fp = fopen('xx.log', 'r');
    
    while(!feof($fp)){
       $line = trim(fgets($fp));
       // 跳过空行
       if(!$line){
          continue;
       }
       // 以 ==== 字符串开头时
       if(strpos($line, '====') === 0){
          if($data){
             //处理上一条记录
          }
          $data = array();
       }
       // 分割字符串
       list($key, $value) = explode(':', $line, 2);
       // 写入到数组
       $data[$key] = trim($value);
    }
    
    fclose($fp);
    
    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    专题推荐:php javascript java c++
    上一篇:Eclipse如何调试php的CI项目 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 你知道如何用PHP实现多进程吗• PHP与MySQL连接的方法总结• 工具包分享:PHP实现滑块验证图片• 求大神解答!ajax处理php返回的xml文档的问题• php实现mysql数据库分表分段备份_php实例
    1/1

    PHP中文网