Home >php教程 >php手册 >PHP生成XML格式数据与解析xml数据

PHP生成XML格式数据与解析xml数据

WBOY
WBOYOriginal
2016-05-25 16:42:042083browse

本文章来详细的介绍一下关于PHP生成XML格式数据与解析xml数据程序代码,有需要学习的朋友可参考参考,先看xml文档,代码如下:

<?xml version="1.0" encoding="utf-8" 
<article> 
    <item> 
        <title size="1">title1</title> 
        <content>content1</content> 
        <pubdate>2009-10-11</pubdate> 
    </item> 
    <item> 
        <title size="1">title2</title> 
        <content>content2</content> 
        <pubdate>2009-11-11</pubdate> 
    </item> 
</article>

那么我们用php如何生成xml格式数据呢

方法1:使用纯粹的PHP代码生成字符串,并把这个字符串写入一个以XML为后缀的文件,这是最原始的生成XML的方法,不过有效.

PHP代码如下:

<?PHP 
$data_array = array( 
    array( 
    &#39;title&#39; => &#39;title1&#39;, 
    &#39;content&#39; => &#39;content1&#39;, 
        &#39;pubdate&#39; => &#39;2009-10-11&#39;, 
    ), 
    array( 
    &#39;title&#39; => &#39;title2&#39;, 
    &#39;content&#39; => &#39;content2&#39;, 
    &#39;pubdate&#39; => &#39;2009-11-11&#39;, 
    ) 
); 
$title_size = 1; 
$xml = "<?xml version=\"1.0\" encoding=\"utf-8\"n"; 
$xml .= "<article>\n"; 
foreach ($data_array as $data) { 
    $xml .= create_item($data[&#39;title&#39;], $title_size, $data[&#39;content&#39;], $data[&#39;pubdate&#39;]); 
} 
$xml .= "</article>\n"; 
echo $xml; 
//  创建XML单项 
function create_item($title_data, $title_size, $content_data, $pubdate_data) { 
    $item = "<item>\n"; 
    $item .= "<title size=\"" . $title_size . "\">" . $title_data . "</title>\n"; 
    $item .= "<content>" . $content_data . "</content>\n"; 
    $item .= " <pubdate>" . $pubdate_data . "</pubdate>\n"; 
    $item .= "</item>\n";
    return $item; 
} 
?>

方法2:使用DomDocument生成XML文件

创建节点使用createElement方法,创建文本内容使用createTextNode方法,添加子节点使用appendChild方法,创建属性使用createAttribute方法,代码如下:

<?PHP 
$data_array = array( 
    array( 
    &#39;title&#39; => &#39;title1&#39;, 
    &#39;content&#39; => &#39;content1&#39;, 
        &#39;pubdate&#39; => &#39;2009-10-11&#39;, 
    ), 
    array( 
    &#39;title&#39; => &#39;title2&#39;, 
    &#39;content&#39; => &#39;content2&#39;, 
    &#39;pubdate&#39; => &#39;2009-11-11&#39;, 
    ) 
); 
//  属性数组 
$attribute_array = array( 
    &#39;title&#39; => array( 
    &#39;size&#39; => 1 
    ) 
); 
//  创建一个XML文档并设置XML版本和编码。。 
$dom=new DomDocument(&#39;1.0&#39;, &#39;utf-8&#39;); 
//  创建根节点 
$article = $dom->createElement(&#39;article&#39;); 
$dom->appendchild($article); 
foreach ($data_array as $data) { 
    $item = $dom->createElement(&#39;item&#39;); 
    $article->appendchild($item); 
    create_item($dom, $item, $data, $attribute_array); 
} 
echo $dom->saveXML(); 
function create_item($dom, $item, $data, $attribute) { 
    if (is_array($data)) { 
        foreach ($data as $key => $val) { 
            //  创建元素 
            $$key = $dom->createElement($key); 
            $item->appendchild($$key); 
            //  创建元素值 
            $text = $dom->createTextNode($val); 
            $$key->appendchild($text); 
            if (isset($attribute[$key])) {  //  如果此字段存在相关属性需要设置 
                foreach ($attribute[$key] as $akey => $row) { 
                    //  创建属性节点 
                    $$akey = $dom->createAttribute($akey); 
                    $$key->appendchild($$akey); 
                    // 创建属性值节点 
                    $aval = $dom->createTextNode($row); 
                    $$akey->appendChild($aval); 
                } 
            }   //  end if 
        } 
    }   //  end if 
}   //  end function 
?>

下面我们以学生信息表student,需要提供给第三方调用,并有id,name,sex,age分别记录学生的姓名、性别、年龄等信息,代码如下:

CREATE TABLE `student` ( 
`id` int(11) NOT NULL auto_increment, 
`name` varchar(50) NOT NULL, 
`sex` varchar(10) NOT NULL, 
`age` smallint(3) NOT NULL default &#39;0&#39;, 
PRIMARY KEY (`id`) 
) ENGINE=MyISAM DEFAULT CHARSET=utf8;


首先,建立createXML.php文件,先连接数据库,获取数据,代码如下:

<?php
include_once ("connect.php"); //连接数据库 
$sql = "select * from student"; 
$result = mysql_query($sql) or die("Invalid query: " . mysql_error()); 
while ($row = mysql_fetch_array($result)) { 
$arr[] = array( 
&#39;name&#39; => $row[&#39;name&#39;], 
&#39;sex&#39; => $row[&#39;sex&#39;], 
&#39;age&#39; => $row[&#39;age&#39;] 
); 
}
?>

这个时候,数据就保存在$arr中,你可以使用print_r打印下数据测试,接着,建立xml,循环数组,将数据写入到xml对应的节点中,代码如下:

<?php
$doc = new DOMDocument(&#39;1.0&#39;, &#39;utf-8&#39;); // 声明版本和编码 
$doc->formatOutput = true; 
$r = $doc->createElement("root"); 
$doc->appendChild($r); 
foreach ($arr as $dat) { 
$b = $doc->createElement("data"); 
$name = $doc->createElement("name"); 
$name->appendChild($doc->createTextNode($dat[&#39;name&#39;])); 
$b->appendChild($name); 
$sex = $doc->createElement("sex"); 
$sex->appendChild($doc->createTextNode($dat[&#39;sex&#39;])); 
$b->appendChild($sex); 
$age = $doc->createElement("age"); 
$age->appendChild($doc->createTextNode($dat[&#39;age&#39;])); 
$b->appendChild($age); 
$r->appendChild($b); 
} 
echo $doc->saveXML();
?>

我们调用了PHP内置的类DOMDocument来处理与生成xml,最终生成的xml格式,代码如下:

 

 

李王皓 

 

21 

 

… 

 

获取XML格式数据

现在我们假设要从第三方获取学生信息,数据格式是XML,我们需要使用PHP解析XML,然后将解析后的数据显示或者写入本地数据库,而这里关键的一步是解析XML.

PHP有很多中方法可以解析XML,其中PHP提供了内置的XMLReader类可以循序地浏览过xml档案的节点,你可以想像成游标走过整份文件的节点,并抓取需要的内容,使用XMLReader是高效的,尤其是读取非常大的xml数据,相对其他方法,使用XMLReader消耗内存非常少,代码如下:

<?php
header("Content-type:text/html; Charset=utf-8");
$url = "你的xml路么";
$reader = new XMLReader(); //实例化XMLReader
$reader->open($url); //获取xml
$i = 1;
while ($reader->read()) {
    if ($reader->nodeType == XMLReader::TEXT) { //判断node类型
        $m = $i % 3;
        if ($m == 1) $name = $reader->value; //读取node值
        if ($m == 2) $sex = $reader->value;
        if ($m == 0) {
            $age = $reader->value;
            $arr[] = array(
                &#39;name&#39; => $name,
                &#39;sex&#39; => $sex,
                &#39;age&#39; => $age
            );
        }
        $i++;
    }
}
//print_r($arr);
?>

为了将数据name,sex和age分开,我们使用$i%3来判断取模,因为在获取的xml中,节点data下的信息是以3个子节点存在的.

生成与读取xml文档的方法有很多,下面我就不介绍了,大家可参考相关的文档.


本文地址:

转载随意,但请附上文章地址:-)

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn