• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

用PHP实现读取和编写XML DOM代码_php技巧

php 搞代码 3年前 (2022-01-26) 17次浏览 已收录 0个评论
 <BR>// 用 DOM 读取 XML <BR>$doc = new DOMDocument(); <BR>$doc->load(‘test.xml'); <BR>$books = $doc->getElementsByTagName(“book”); <BR>foreach( $books as $book ){ <BR>$authors = $book->getElementsByTagName(“author”); <BR>$author = $authors->item(0)->nodeValue; // nodeValue属 性可根据节点的类型来设置或返回某个节点的值。 <BR>$publishers = $book->getElementsByTagName(“publisher”); <BR>$publisher = $publishers->item(0)->nodeValue; <BR>$titles = $book->getElementsByTagName( ”title” ); <BR>$title = $titles->item(0)->nodeValue; <BR>echo ”Title: $title <br> Author: $author <br> Publisher: $publisher<br><hr><br>”; <BR>} <BR>


/*
脚本首先创建一个 new DOMdocument 对象,用 load 方法把图书 XML 装入这个对象。之后,脚本 用 getElementsByName 方法得到指定名称下的所有元素的列表。
在 book 节点的循环中,脚本用 getElementsByName 方法获得 author、 publisher 和 title 标记的 nodeValue。nodeValue 是节点中的文本。脚本然后显示这些值。
*/

 <BR>// 用 SAX 解析器读取 XML <BR>$g_books = array(); <BR>$g_elem = null; <BR>function startElement( $parser, $name, $attrs ){ <BR>global $g_books, $g_elem; <BR>if ( $name == 'BOOK' ) $g_books []= array(); <BR>$g_elem = $name; <BR>} <BR>function endElement( $parser, $name ){ <BR>global $g_elem; <BR>$g_elem = null; <BR>} <BR>function textData( $parser, $text ){ <BR>global $g_books, $g_elem; <BR>if ( $g_elem == 'AUTHOR' || $g_elem == 'PUBLISHER' || $g_elem == 'TITLE' ){ <BR>$g_books[ count( $g_books ) - 1 ][ $g_elem ] = $text; <BR>} <BR>} <BR>$parser = xml_parser_create(); <BR>xml_set_element_handler( $parser, ”startElement”, ”endElement” ); <BR>xml_set_character_data_handler( $parser, ”textData” ); <BR>$f = fopen( 'test.xml', 'r' ); <BR>while( $data = fread( $f, 4096 ) ){ <BR>xml_parse( $parser, $data ); <BR>} <BR>xml_parser_free( $parser ); <BR>foreach( $g_books as $book ){ <BR>echo $book['TITLE'].” - ”.$book['AUTHOR'].” - ”; <BR>echo $book['PUBLISHER'].””; <BR>} <BR>


/*
脚本首先设置 g_books 数组,它在内存中容纳所有图书和图书信息,g_elem 变量保存脚本目前正在处理的标记的名称。然后脚 本定义回调函数。在这个示例中,回调函数是 startElement、endElement 和 textData。在打开和关闭标记的时候,分别调 用 startElement 和 endElement 函数。在开始和结束标记之间的文本上面,调用 textData。
在这个示例中,startElement 标记查找 book 标记,在 book 数组中开始一个新元素。然 后,textData 函数查看当前元素,看它是不是 publisher、title 或 author 标记。如果是,函数就把当前文本放入当前图 书。
为了让解析继续,脚本用 xml_parser_create 函数创建解析器。然后,设置回调句柄。之后,脚本读取文件并把文件的大块 内容发送到解析器。在文件读取之后,xml_parser_free 函数删除解析器。脚本的末尾输出 g_books 数组的内容。
*/
// 用正则表达式解析 XML

 <BR>$xml = ”"; <BR>$f = fopen( 'test.xml', 'r' ); <BR>while( $data = fread( $f, 4096 ) ) { $xml .= $data; } <BR>fclose( $f ); <BR>preg_match_all( ”/\<book\>(.*?)\<\/book\>/s”, $xml, $bookblocks ); <BR>foreach( $bookblocks[1] as $block ){ <BR>preg_match_all( ”/\preg_match_all( ”/\<title\>(.*?)\<\/title\>/”, $block, $title ); <BR>preg_match_all( ”/\<publisher\>(.*?)\<\/publisher\>/”, $block, $publisher ); <BR>echo( $title[1][0].” - ”.$author[1][0].” - ”. $publisher[1][0].”” ); <BR>} <BR>


/*
我从不建议使用正则表达式读取 XML,但是有时它是兼容性最好的方式,因为正则表达式函数总是可用的。不要用正则表达式读取直接来自用户 的 XML,因为无法控制这类 XML 的格式或结构。应当一直用 DOM 库或 SAX 解析器读取来自用户的 XML。
*/
// 用 DOM 编写 XML

 <BR>$books = array(); <BR>$books [] = array( <BR>'title' => 'PHP Hacks', <BR>'author' => 'Jack Herrington', <BR>'publisher' => ”O'Reilly” <BR>); <BR>$books [] = array( <BR>'title' => 'Podcasting Hacks', <BR>'author' => 'Jack Herrington', <BR>'publisher' => ”O'Reilly” <BR>); <BR>$doc = new DOMDocument(); <BR>$doc->formatOutput = true; <BR>$r = $doc->createElement( ”books” ); <BR>$doc->appendChild( $r ); <BR>foreach( $books as $book ){ <BR>$b = $doc->createElement( ”book” ); <BR>$author = $doc->createElement( ”author” ); <BR>$author->appendChild( $doc->createTextNode( $book['author'] ) ); <BR>$b->appendChild( $author ); <BR>$title = $doc->createElement( ”title” ); <BR>$title->appendChild( $doc->createTextNode( $book['title'] ) ); <BR>$b->appendChild( $title ); <BR>$publisher = $doc->createElement( ”publisher” ); <BR>$publisher->appendChild( $doc->createTextNode( $book['publisher'] ) ); <BR>$b->appendChild( $publisher ); <BR>$r->appendChild( $b ); <BR>} <BR>//echo $doc->saveXML(); <BR>


/*
在脚本的顶部,用一些示例图书装入了 books 数组。这个数据可以来自用户也可以来自数据库。
示例图书装入之后,脚本创建一个 new DOMDocument,并把根节点 books 添加到它。然后脚本为每本书 的 author、title 和 publisher 创建节点,并为每个节点添加文本节点。每个 book 节点@本文来*源gaodai#ma#com搞*!代#%^码$网*的最后一步是重新把它添加到根节 点 books。
使用 DOM 的真正价值在于它创建的 XML 总是格式正确的。但是如果不能用 DOM 创建 XML 时该怎么办?
Xml代码

 <BR><?php <BR>PHP 编写xml <BR>$books = array(); <BR>$books [] = array( <BR>'title' => 'PHP Hacks', <BR>'author' => 'Jack Herrington', <BR>'publisher' => ”O'Reilly” <BR>); <BR>$books [] = array( <BR>'title' => 'Podcasting Hacks', <BR>'author' => 'Jack Herrington', <BR>'publisher' => ”O'Reilly” <BR>); <BR>?> <BR> <BR><?php <BR>foreach( $books as $book ) <BR>{ <BR>?> <BR> <BR><title><?php echo( $book['title'] ); ?></title> <BR><?php echo( $book['author'] ); ?> <BR> <BR><?php echo( $book['publisher'] ); ?> <BR> <BR> <BR><?php <BR>} <BR>?> <BR> <BR>


实例中用到的 test.xml 如下:

 <BR><?xml version=”1.0″ encoding=”utf8″?> <BR> <BR> <BR>Jack Herrington <BR><title>PHP Hacks</title> <BR>O'Reilly <BR> <BR> <BR>Jack Herrington <BR><title>Podcasting Hacks</title> <BR>O'Reilly <BR> <BR> <BR>

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:用PHP实现读取和编写XML DOM代码_php技巧
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址