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

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

May 25, 2016 pm 04:42 PM
PHP는 XML을 생성

本文章来详细的介绍一下关于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文档的方法有很多,下面我就不介绍了,大家可参考相关的文档.


本文地址:

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

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)