[分享] 特定 context 解析
理論上應該存在著更好的方法,這裡純粹是土法鍊鋼。
比方有個文字檔案如下
CONTEXT alarm_id = 1001
alarm_type = equipment
alarm_level = critical
alarm_text = eqn 1-1-1-1 fault detec
ted. some error accoured.
alarm_time = 2012/04/26 09:00:01 am
CONTEXT alarm_id = 1000
alarm_type = qos
alarm_level = major
alarm_text = tcp/ip package losed.
alarm_time = 2012/04/25 08:59:33 am
若依聖殿的寫法
mixed tmps=explode(read_file("/alarm.txt"),"CONTEXT");
先對 CONTEXT 做 explode(split),這可以取得每一段的 alarm
msg,接著各別取出 alarm_id、alarm_type 等。
foreach(tmp in tmps)
{
str = "alarm_id = ";
a = strsrch(tmp,str) + strlen(str);
b = a;
while(1)
{
if(tmp[b..b]=="\n")
break;
b++;
}
// 這樣就取得 alarm_id 的範圍
alarm_id = tmp[a..b-1];
.
.
}
上面簡單的說就是,先判斷 "alarm_id = " 這個字串的起始位置
,這時候 tmp[a..a] = "a" 這個字串,加上 strlen(str) 後,就
變成 alarm_id 的第一個字串(也就是 1001 的 "1")
而 b 則讓它累加,直到偵測到換行字元 tmp[b..b] == "\n" 為止
,這時 tmp[a..b-1] 就是 "1001"
大部份欄位都可以用這種方式取出,但是像 alarm_text 這種不固
定行數、而且斷行斷在奇怪地方的(detec 接下行的 ted),我使用
的方法是判斷它下一個欄位(它下一欄是固定的 alarm_time)
foreach(tmp in tmps)
{
.
.
str = "alarm_text = ";
a = strsrch(tmp,str) + strlen(str);
b = a;
str2 = " alarm_time = ";
s = strlen(str2);
while(1)
{
if(tmp[b..b+s-1]==str2)
break;
b++;
}
alarm_text = replace(tmp[a..b-1],"\n","");
.
.
}
上面的做法也類似,在 b 的判斷部份則是以它下一個參數
"alarm_time" 做為終止字串的判斷,藉此取出 alarm_text
的全部內容,並將其換行符號拿掉,這時以 id = 1001 為
例..
alarm_text = "eqn 1-1-1-1 fault detected. some error accoured."
===================================================
--
※ 發信站: 批踢踢實業坊(ptt.cc)
※ 編輯: laechan 來自: 111.81.173.167 (04/26 10:54)
※ 編輯: laechan 來自: 210.61.157.53 (06/12 12:43)
mud_sanc 近期熱門文章
PTT遊戲區 即時熱門文章
21
33