基于事件的解析器集中在 XML 文檔的內容,而不是它們的結果。正因如此,基于事件的解析器能夠比基于樹的解析器更快地訪問數據。
請看下面的 XML 片段:
from John /from
基于事件的解析器把上面的 XML 報告為一連串的三個事件:
上面的 XML 范例包含了形式良好的 XML。不過這個例子是無效的 XML,因為沒有與它關聯的文檔類型聲明 (DTD),也沒有內嵌的 DTD。
不過,在使用 Expat 解析器時,這沒有區別。Expat 是不檢查有效性的解析器,忽略任何 DTD。
作為一款基于事件、非驗證的 XML 解析器,Expat 快速且輕巧,十分適合 PHP 的 web html' target='_blank'>應用程序。
注釋:XML 文檔必須形式良好,否則 Expat 會生成錯誤。
我們要在 PHP 中初始化 XML 解析器,為不同的 XML 事件定義處理器,然后解析這個 XML 文件。
?php//Initialize the XML parser$parser=xml_parser_create();//Function to use at the start of an elementfunction start($parser,$element_name,$element_attrs) switch($element_name) case NOTE : echo -- Note -- br / break; case TO : echo To: break; case FROM : echo From: break; case HEADING : echo Heading: break; case BODY : echo Message: //Function to use at the end of an elementfunction stop($parser,$element_name) echo br / //Function to use when finding character datafunction char($parser,$data) echo $data;//Specify element handlerxml_set_element_handler($parser, start , stop //Specify data handlerxml_set_character_data_handler($parser, char //Open XML file$fp=fopen( test.xml , r //Read datawhile ($data=fread($fp,4096)) xml_parse($parser,$data,feof($fp)) or die (sprintf( XML Error: %s at line %d , xml_error_string(xml_get_error_code($parser)), xml_get_current_line_number($parser)));//Free the XML parserxml_parser_free($parser);?
以上代碼的輸出:
-- Note --To: GeorgeFrom: JohnHeading: ReminderMessage: Don't forget the meeting!工作原理解釋:通過 xml_parser_create() 函數初始化 XML 解析器創建配合不同事件處理程序的的函數添加 xml_set_element_handler() 函數來定義,當解析器遇到開始和結束標簽時執行哪個函數添加 xml_set_character_data_handler() 函數來定義,當解析器遇到字符數據時執行哪個函數通過 xml_parse() 函數來解析文件 test.xml 萬一有錯誤的話,添加 xml_error_string() 函數把 XML 錯誤轉換為文本說明調用 xml_parser_free() 函數來釋放分配給 xml_parser_create() 函數的內存
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。
新聞熱點
疑難解答