[分享] 特定 context 解析

看板mud_sanc (Sanctuary - 聖殿)作者 (小太保)時間13年前 (2012/04/26 10:45), 編輯推噓0(000)
留言0則, 0人參與, 最新討論串1/1
理論上應該存在著更好的方法,這裡純粹是土法鍊鋼。 比方有個文字檔案如下 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)
文章代碼(AID): #1FcBRKu- (mud_sanc)
文章代碼(AID): #1FcBRKu- (mud_sanc)