❶ (使用php语言)Simple_XML中如果对中文结点进行解析
其答枝实可以用php把xml生成数组然后在处理.
<?php
/*
程序:get_xml_array.php
作用:将xml数据生成数组,数组格式:标签名=>值。
时间:2009-3-20
*/
//定义一个将xml标签对应值对象
class AminoAcid {
function AminoAcid ($aa)
{
foreach ($aa as $k=>$v){
$this->$k = $aa[$k];
}
}
}
/*
函数readDarabase
参数:
$file:文件路径。
$tree:根据此生成循环数组的xml标签
*/
function readDatabase($file,$tree)
{
$data = implode("",file($file));
//echo $data;
$parser = xml_parser_create();
xml_parser_set_option($parser, XML_OPTION_CASE_FOLDING, 0);
xml_parser_set_option($parser, XML_OPTION_SKIP_WHITE, 1);
xml_parse_into_struct($parser, $data, $values, $tags);
xml_parser_free($parser);
foreach ($tags as $key=>$val) {
if ($key == $tree) {
$molranges = $val;
for ($i=0; $i < count($molranges); $i+=2) {
$offset = $molranges[$i] + 1;
$len = $molranges[$i + 1] - $offset;
$tdb[] = parseMol(array_slice($values, $offset, $len));
}
} else {
continue;
}
}
return $tdb;
}
function parseMol($mvalues)
{
for ($i=0; $i < count($mvalues); $i++) {
$mol[$mvalues[$i]["tag"]] = $mvalues[$i]["value"];
}
//print_r( new AminoAcid($mol));
return new AminoAcid($mol);
}
$tree = "monster";
$db = readDatabase("1.xml",$tree);
print_r($db);
?>
其中1.xml就是
<?xml version="1.0" encoding="utf-8"?>
<monster>
<xiyou:姓名 type='text'>孙桥肆悟空</xiyou:姓名>
<xiyou:技能 type='text'>火眼金睛</xiyou:技能>
<xiyou:年清消敏龄 type='text'>638</xiyou:年龄>
</monster>
用这个处理是将数组生成了一个与其标签对应的数组,我经常用这个,感觉数据处理起来比较方便,如果非要用Simple_XML其实更简单一些。你可以参考一下,这个
http://hi..com/hoveriann/blog/item/6af70bfbd9546662024f56dc.html