/**
* 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>

PHP仍然流行的原因是其易用性、灵活性和强大的生态系统。1)易用性和简单语法使其成为初学者的首选。2)与web开发紧密结合,处理HTTP请求和数据库交互出色。3)庞大的生态系统提供了丰富的工具和库。4)活跃的社区和开源性质使其适应新需求和技术趋势。

PHP和Python都是高层次的编程语言,广泛应用于Web开发、数据处理和自动化任务。1.PHP常用于构建动态网站和内容管理系统,而Python常用于构建Web框架和数据科学。2.PHP使用echo输出内容,Python使用print。3.两者都支持面向对象编程,但语法和关键字不同。4.PHP支持弱类型转换,Python则更严格。5.PHP性能优化包括使用OPcache和异步编程,Python则使用cProfile和异步编程。

PHP主要是过程式编程,但也支持面向对象编程(OOP);Python支持多种范式,包括OOP、函数式和过程式编程。PHP适合web开发,Python适用于多种应用,如数据分析和机器学习。

PHP起源于1994年,由RasmusLerdorf开发,最初用于跟踪网站访问者,逐渐演变为服务器端脚本语言,广泛应用于网页开发。Python由GuidovanRossum于1980年代末开发,1991年首次发布,强调代码可读性和简洁性,适用于科学计算、数据分析等领域。

PHP适合网页开发和快速原型开发,Python适用于数据科学和机器学习。1.PHP用于动态网页开发,语法简单,适合快速开发。2.Python语法简洁,适用于多领域,库生态系统强大。

PHP在现代化进程中仍然重要,因为它支持大量网站和应用,并通过框架适应开发需求。1.PHP7提升了性能并引入了新功能。2.现代框架如Laravel、Symfony和CodeIgniter简化开发,提高代码质量。3.性能优化和最佳实践进一步提升应用效率。

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

PHP类型提示提升代码质量和可读性。1)标量类型提示:自PHP7.0起,允许在函数参数中指定基本数据类型,如int、float等。2)返回类型提示:确保函数返回值类型的一致性。3)联合类型提示:自PHP8.0起,允许在函数参数或返回值中指定多个类型。4)可空类型提示:允许包含null值,处理可能返回空值的函数。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3汉化版
中文版,非常好用

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

Dreamweaver CS6
视觉化网页开发工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

禅工作室 13.0.1
功能强大的PHP集成开发环境