以下是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]+)[^:]+.*
阿里云显示是正常的,但是就是提取不出来,应该是什么细节没注意到
立即学习“Java免费学习笔记(深入)”;
以下是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]+)[^:]+.*
阿里云显示是正常的,但是就是提取不出来,应该是什么细节没注意到
立即学习“Java免费学习笔记(深入)”;
贴一个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);
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
C++高性能并发应用_C++如何开发性能关键应用
Java AI集成Deep Java Library_Java怎么集成AI模型部署
Golang后端API开发_Golang如何高效开发后端和API
Python异步并发改进_Python异步编程有哪些新改进
C++系统编程内存管理_C++系统编程怎么与Rust竞争内存安全
Java GraalVM原生镜像构建_Java怎么用GraalVM构建高效原生镜像
Python FastAPI异步API开发_Python怎么用FastAPI构建异步API
C++现代C++20/23/26特性_现代C++有哪些新标准特性如modules和coroutines
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号