搜尋
首頁php教程php手册DOMXML函数笔记

dom|xml|笔记|函数

/**
* DOMXML函数笔记
* 连接php_domxml.dll后
* 用get_defined_functions()得到domxml支持函数
*
* 目前domxml不支持非iso-8859-1以外的语言声明
* 支持
* 不支持
* 因此需要改造成这样,可能需要
* utf8_encode() utf8_decode() 函数进行处理
*
* 函数列表
* string domxml_version(void)  返回domxml的版本号
* object xmldoc(string str)    从字符串创建XML的Domdocument对象
* object xmldocfile(string filename)   从文件创建XML的Domdocument对象
* object xmltree(string str)   解析xml文档,返回树状结构,不能用domxml函数改变
* resource domxml_add_root(resource doc,string name)  添加根节点
* string domxml_dumpmem(resource doc)  将domxml对象转化为XML串。这个函数有一个问题,他会在第一个汉字前面加一个扩展ascii字符,形如nnn;
* domxml_node_attributes
* domxml_elem_get_attribute
* domxml_elem_set_attribute
* array domxml_node_children(object doc|node)  返回子节点
* domxml_node_new_child
* object domxml_node(string name)  创建一个节点节点
* domxml_node_unlink_node
* int domxml_node_set_content(resource doc,string content)  设置节点内容
* object domxml_new_xmldoc(string version)  创建新的空XML对象
* xpath_new_context
* xpath_eval
* xpath_eval_expression
* xptr_new_context
* xptr_eval
* object domxml_root(object doc)  返回根节点
* array domxml_attributes(resource note)  获取节点属性
* object domxml_get_attribute(resource doc,string name)  读取属性
* domxml_getattr
* object domxml_set_attribute(resource doc,string name,string value)  添加属性
* domxml_setattr
* array domxml_children(object doc|node)  返回子节点
* resource domxml_new_child(string name,string content)  添加子节点
* domxml_unlink_node
* set_content
* new_xmldoc
*
*/
?>

<br><?php <br/>// 文档 xml源树.xml 内容<br>$testxml = '<br><?xml version="1.0" encoding="GB2312"?> <br><root><br><note>读取xml文档时,处理器将形成一个树,我们将其叫做源树。该树具有表中的各种类型的节点。<br></note><br><title>源树具有的节点</title>
<br><table>
<br><tr>
<th>节点类型</th>
<th>说明</th>
</tr>
<br><tr>
<td>Root(根)</td>
<td>这是树的根节点。可以出现在树的任何地方。根节点只具有一个子节点,子节点指的是xml文档中的文档元素节点。</td>
</tr>
<br><tr>
<td>Element(元素)</td>
<td>这种节点用于文档中的任何元素。元素节点的子节点可以是其内容的元素节点、注释节点、处理信息节点以及文本节点。</td>
</tr>
<br><tr>
<td>Text(文本)</td>
<td>文档中出现的所有文本,都分组归入到文本节点中。文本节点不可以有同为文本节点的紧接着的前或后的兄弟节点。</td>
</tr>
<br><tr>
<td>Attribute(属性)</td>
<td>每一个元素节点都有一套自己附加的属性节点。默认的属性值以与指定属性一样的方法来处理。这些节点都没有子节点。</td>
</tr>
<br><tr>
<td>Namespace(名称)</td>
<td>对于每一个以xlmns:和属性节点开头的元素,都有一个名称空格节点。这些节点没有子节点。</td>
</tr>
<br><tr>
<td>Processing Instruction(处理指令)</td>
<td>每一个处理指令都有一个单独的节点。这些节点都没有子节点。</td>
</tr>
<br><tr>
<td>Comment(注释)</td>
<td>每一个都有一个注释节点。这些节点都没有子节点。</td>
</tr>
<br>
</table>
<br></root><br>';<br><br>echo "domxml版本:".domxml_version();<br>echo "<p>  </p>";<br>// xmltree domxml_dumpmem<br>$filename = "xml源树.xml";<br>//$filename = "resume.xml";<br>$fp = fopen($filename,"r"); <br>$inXML = fread($fp,filesize($filename)); <br>fclose($fp); <br>// 删除语言设定<br>//$inXML = str_replace(' encoding="GB2312"',"",$inXML);<br>$inXML = eregi_replace(' encoding="[a-z0-9_-]+"',"",$inXML);<br><br>$doc = xmltree($inXML);    // 使用xmltree解析<br>$myxml = $doc->dumpmem();  // 转换成字串,头为  xml version="1.0"<br>                           // 如果再执行一次,头将变成  xml version="1.0" encoding="ISO-8859-1"<br>//$myxml = eregi_replace('[0-9]+;',"",$myxml); // 删除<br>echo "用xmltree解析<br>";<br>echo "<textarea cols="60" rows="5">$myxml</textarea><br>";<br>//print_r($doc);  // 可以看到整个树 亦可用var_dump($doc);<br><br>// xmldoc<br>$doc = xmldoc($inXML); <br>$myxml = $doc->dumpmem();<br>echo "用xmldoc解析<br>";<br>echo "<textarea cols="60" rows="5">$myxml</textarea><br>";<br>//print_r($doc); // 只能看到根节点<br><br>// domxml_new_xmldoc<br>$doc = domxml_new_xmldoc("1.0");<br><br>$root = $doc->add_root("HTML");<br>$head = $root->new_child("HEAD", "");<br>$head->new_child("TITLE", "DOMXML 测试0");<br>$head->new_child("TITLE", "DOMXML 测试1");<br>$head->set_attribute("Language", "ge");<br>domxml_node_set_content($head,"ppp"); // 设置节点的内容,多次执行是叠加的<br>domxml_node_set_content($head,"ttt");<br><br>// 是乎函数名中只有1-2个"_"的函数,可作为对象的方法使用<br><br>$myxml = $doc->dumpmem();<br>echo "自定义xml<br>";<br>echo "<textarea cols="60" rows="5">$myxml</textarea><br>";<br><br>// 节点的遍历<br>/**<br>  节点结构<br>  DomElement Object<br>    type = 1<br>    tagname = 节点名<br>  DomText Object<br>    type = 3<br>    content = 节内容点<br>  DomCData Object<br>    type = 4<br>    content = 节内容点<br><br>  DomProcessingInstruction Object<br>    type 无<br>    target = 处理指令<br>    data = 参数<br>                    <br>*/<br>$ar[] = $doc->root();  // 取得根节点<br>$ar[] = $ar[count($ar)-1]->children();<br>$ar[] = $ar[count($ar)-1][0]->children();<br><br>// 函数domxml_children() 不能返回节点参数<br>// 返回节点参数需要使用domxml_attributes()<br>//var_dump(domxml_attributes($head));<br>//print_r($ar[1][0]->attributes());<br>//print_r($ar);<br><br>function xml_dumpmem($xmldoc) {<br>  static $mode = 0;<br>  $xmlstr = "";<br>  // 获取节点,保存在数组中<br>  if(get_class($xmldoc) == "DomDocument") {<br>    $xmlstr = '<?xml version="1.0" encoding="gb2312"?>'."\n";<br>    if(count($xmldoc->children) == 1)  // 根节点,没有其他成员<br>      $docs[] = $xmldoc->root();<br>    else<br>      $docs = $xmldoc->children();  // 根节点,有其他成员<br>  }else {<br>    $docs = $xmldoc->children();  // 一般节点<br>  }<br>  <br>//  echo __LINE__."<br>";<br>  foreach($docs as $doc) {<br>    $attr = $doc->attributes();<br>    switch($doc->type) {<br>      case 1:<br>        $xmlstr .= "tagname}";  // 标签头<br>        if($attr) {<br>          foreach($attr as $key)<br>            $xmlstr .= " {$key->name}=\"{$key->value}\"";  // 标签参数<br>        }<br>        $xmlstr .= ">";  // 标签结束<br>        $xmlstr .= xml_dumpmem($doc);  // 进入子节点<br>        $xmlstr .= "{$doc->tagname}>";  // 闭合标签<br>        break;<br>      case 3:<br>        $xmlstr .= $doc->content;<br>        break;<br>      case 4:<br>        $xmlstr .= "        $xmlstr .= $doc->content;<br>        $xmlstr .= "]]>";<br>        break;<br>      default:<br>        if(get_class($doc) == "DomProcessingInstruction") {<br>          $xmlstr .= "{$doc->target}";<br>          $xmlstr .= " {$doc->data}?>\n";<br>        }<br>        break;<br>    }<br>  }<br>  return $xmlstr;<br>}<br><br>if(1) {<br>  $filename = "resume.xml";<br>//  $filename = "resume.xsl";<br>  $filename = "xml源树.xml";<br>  $fp = fopen($filename,"r"); <br>  $inXML = fread($fp,filesize($filename)); <br>  fclose($fp); <br>  $inXML = eregi_replace(' encoding="[a-z0-9_-]+"',"",$inXML);<br>//  $doc = xmltree($inXML);    // 使用xmltree解析<br>  $doc = xmldoc($inXML);    // 使用xmldoc解析<br>}<br><br>// 不能用来解析xsl文档<br><br>$myxml = xml_dumpmem($doc);<br>echo "自己写一个dumpmem就不出错了<br>";<br>echo "<textarea cols="60" rows="5">$myxml</textarea><br>";<br>print_r($doc);<br><br>?><br>



陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境