Rumah pembangunan bahagian belakang tutorial php PHP读写XML文件技巧_PHP教程

PHP读写XML文件技巧_PHP教程

Jul 20, 2016 am 11:18 AM
char header html php text xml Biasa digunakan Kemahiran dokumen Baca dan tulis

 常用 如下 几行:

header("content-type:text/html; charset=utf-8"); //指定PHP使用UTF-8编码
$xml = simplexml_load_file("example.xml"); //读取xml文件
$newxml = $xml->asXML(); //标准化$xml
$fp = fopen("newxml.xml", "w"); //新建xml文件
fwrite($fp, $newxml); //写入-------xml文件
fclose($fp);

PHP可以方便的生成和读取XML文件。PHP主要通过DOMDocument、DOMElement和DOMNodeList来完成XML的读取与写入操作的。下面就简要说明下如何使用这些类。

一.生成XML文件
对于一个如下XML文件。

[html]


PHP访问MySql数据库 初级篇
http://blog.csdn.net/morewindows/article/details/7102362



PHP访问MySql数据库 初级篇
http://blog.csdn.net/morewindows/article/details/7102362

我们来看看如何用PHP来生成:

首先new一个DOMDocument对象并设置编码格式。

$dom = newDOMDocument('1.0', 'UTF-8');

$dom->formatOutput= true;

再创建

结点和结点

$rootelement =$dom->createElement("article");

$title =$dom->createElement("title", "PHP访问MySql数据库 初级篇");

然后创建带文本内容的结点

$link =$dom->createElement("link","http://blog.csdn.net/morewindows/article/details/7102362");

也可以先生成结点再为其添加文本内容。

$link = $dom->createElement("link");

$linktext =$dom->createTextNode('http://blog.csdn.net/morewindows/article/details/7102362');

$link->appendChild($linktext);

然后将

和<link>结点加入到<article>结点中去 <p>$rootelement->appendChild($title);</p> <p>$rootelement->appendChild($link);</p> <p>最后将<article>结点加入到DOMDocument对象中,</article></p> <p>$dom->appendChild($rootelement);</p> <p>这样一个完整的XML就生成完毕了。再整出整个XML,</p> <p>echo $dom->saveXML() ;</p> <p>saveXML()也可以只输入部分XML文本,如echo $dom->saveXML($link);就只会输出<link>结点:<link>http://blog.csdn.net/morewindows/article/details/7102362</p> <p>下面再给出一个完整的PHP中数据内容输出到XML文件的例子。该例子会对将一个PHP数组输出到XML文件中。</p> <p>[php] <?php <br /> //将数组输出到XML文件中 <br> // by MoreWindows( http://blog.csdn.net/MoreWindows ) <br> $article_array = array( <br> "第一篇" => array( <br> "title"=>"PHP访问MySql数据库 初级篇", <br> "link"=>"http://blog.csdn.net/morewindows/article/details/7102362" <br> ), <br> "第二篇" => array( <br> "title"=>"PHP访问MySql数据库 中级篇 Smarty技术", <br> "link"=>"http://blog.csdn.net/morewindows/article/details/7094642" <br> ), <br> "第三篇" => array( <br> "title"=>"PHP访问MySql数据库 高级篇 AJAX技术", <br> "link"=>"http://blog.csdn.net/morewindows/article/details/7086524" <br> ), <br> ); <br> $dom = new DOMDocument('1.0', 'UTF-8'); <br> $dom->formatOutput = true; <br> $rootelement = $dom->createElement("MoreWindows"); <br> foreach ($article_array as $key=>$value) <br> { <br> $article = $dom->createElement("article", $key); <br> $title = $dom->createElement("title", $value['title']); <br> $link = $dom->createElement("link", $value['link']); <br> $article->appendChild($title); <br> $article->appendChild($link); <br> $rootelement->appendChild($article); <br>  </p> <p>} <br> $dom->appendChild($rootelement); <br> $filename = "D:test.xml"; <br> echo 'XML文件大小' . $dom->save($filename) . '字节'; <br> ?> <br> <?php <br /> //将数组输出到XML文件中<br> // by MoreWindows( http://blog.csdn.net/MoreWindows )<br> $article_array = array(<br> "第一篇" => array(<br> "title"=>"PHP访问MySql数据库 初级篇",<br> "link"=>"http://blog.csdn.net/morewindows/article/details/7102362"<br> ),<br> "第二篇" => array(<br> "title"=>"PHP访问MySql数据库 中级篇 Smarty技术",<br> "link"=>"http://blog.csdn.net/morewindows/article/details/7094642"<br> ),<br> "第三篇" => array(<br> "title"=>"PHP访问MySql数据库 高级篇 AJAX技术",<br> "link"=>"http://blog.csdn.net/morewindows/article/details/7086524"<br> ),<br> );<br> $dom = new DOMDocument('1.0', 'UTF-8');<br> $dom->formatOutput = true;<br> $rootelement = $dom->createElement("MoreWindows");<br> foreach ($article_array as $key=>$value)<br> {<br> $article = $dom->createElement("article", $key);<br> $title = $dom->createElement("title", $value['title']);<br> $link = $dom->createElement("link", $value['link']);<br> $article->appendChild($title);<br> $article->appendChild($link);<br> $rootelement->appendChild($article);<br> }<br> $dom->appendChild($rootelement);<br> $filename = "D:test.xml";<br> echo 'XML文件大小' . $dom->save($filename) . '字节';<br> ?><br> 运行该PHP会在D盘上生成test.xml文件(Win7 + XAMPP + IE9.0测试通过)</p> <p> </p> <p>二.读取XML文件 <br> 以读取前文中生成的D:test.xml为例:</p> <p>[php] <?php <br /> //读取XML文件 <br> // by MoreWindows( http://blog.csdn.net/MoreWindows ) <br> $filename = "D:test.xml"; <br> $article_array = array(); <br> <br> $dom = new DOMDocument('1.0', 'UTF-8'); <br> $dom->load($filename); <br> <br> //得到<article>结点 <br> $articles = $dom->getElementsByTagName("article"); <br> echo '<article> 结点个数 ' . $articles->length; <br> foreach ($articles as $article) <br> { <br> $id = $article->getElementsByTagName("id")->item(0)->nodeValue; <br> $title = $article->getElementsByTagName("title")->item(0)->nodeValue; <br> $link = $article->getElementsByTagName("link")->item(0)->nodeValue; <br> $article_array[$id] = array('title'=>$title, 'link'=>$link); <br> } <br> <br> //输出结果 <br> echo "<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">"; <br> var_dump($article_array); <br> echo "</pre><div class="contentsignin">Salin selepas log masuk</div></div>"; <br> ?> <br> <?php <br /> //读取XML文件<br> // by MoreWindows( http://blog.csdn.net/MoreWindows )<br> $filename = "D:test.xml";<br> $article_array = array();</article></article></p> <p> </p> <p>$dom = new DOMDocument('1.0', 'UTF-8');<br> $dom->load($filename);</p> <p>//得到<article>结点<br> $articles = $dom->getElementsByTagName("article");<br> echo '<article> 结点个数 ' . $articles->length;<br> foreach ($articles as $article)<br> {<br> $id = $article->getElementsByTagName("id")->item(0)->nodeValue;<br> $title = $article->getElementsByTagName("title")->item(0)->nodeValue;<br> $link = $article->getElementsByTagName("link")->item(0)->nodeValue;<br> $article_array[$id] = array('title'=>$title, 'link'=>$link);<br> }</article></article></p> <p>//输出结果<br> echo "</p> <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">";<br> var_dump($article_array);<br> echo "</pre><div class="contentsignin">Salin selepas log masuk</div></div>";<br> ?> <p align="left"></p> <div style="display:none;"> <span id="url" itemprop="url">http://www.bkjia.com/PHPjc/371866.html</span><span id="indexUrl" itemprop="indexUrl">www.bkjia.com</span><span id="isOriginal" itemprop="isOriginal">true</span><span id="isBasedOnUrl" itemprop="isBasedOnUrl">http://www.bkjia.com/PHPjc/371866.html</span><span id="genre" itemprop="genre">TechArticle</span><span id="description" itemprop="description">常用 如下 几行: header(content-type:text/html; charset=utf-8); //指定PHP使用UTF-8编码 $xml = simplexml_load_file(example.xml); //读取xml文件 $newxml = $xml-asXML(...</span> </div> <div class="art_confoot"></div> </article>
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

<🎜>: Bubble Gum Simulator Infinity - Cara Mendapatkan dan Menggunakan Kekunci Diraja
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Sistem Fusion, dijelaskan
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1677
14
Tutorial PHP
1278
29
Tutorial C#
1257
24
Apakah kepentingan fungsi session_start ()? Apakah kepentingan fungsi session_start ()? May 03, 2025 am 12:18 AM

session_start () iscrucialinphpformanaginguserSessions.1) itinitiatesanewsessionifnoneexists, 2) resumeSanexistingsession, dan3) setSasessionCookieforcontinuityAcrossrequests, enableingApplicationeUseUshenticationandPersonalConizedConizedContentContentContentContentContentContentContentContentContentContentContentC.

Komposer: Membantu pembangunan PHP melalui AI Komposer: Membantu pembangunan PHP melalui AI Apr 29, 2025 am 12:27 AM

AI boleh membantu mengoptimumkan penggunaan komposer. Kaedah khusus termasuk: 1. Pengoptimuman Pengurusan Ketergantungan: AI menganalisis kebergantungan, mengesyorkan kombinasi versi terbaik, dan mengurangkan konflik. 2. Generasi Kod Automatik: AI menjana fail komposer.json yang sesuai dengan amalan terbaik. 3. Meningkatkan Kualiti Kod: AI mengesan masalah yang berpotensi, memberikan cadangan pengoptimuman, dan meningkatkan kualiti kod. Kaedah ini dilaksanakan melalui pembelajaran mesin dan teknologi pemprosesan bahasa semulajadi untuk membantu pemaju meningkatkan kecekapan dan kualiti kod.

H5: Penambahbaikan utama dalam HTML5 H5: Penambahbaikan utama dalam HTML5 Apr 28, 2025 am 12:26 AM

HTML5 membawa lima penambahbaikan utama: 1. Tag semantik meningkatkan kejelasan kod dan kesan SEO; 2. Sokongan multimedia memudahkan penyembuhan video dan audio; 3. Peningkatan Borang Memudahkan Pengesahan; 4. Offline dan storan tempatan meningkatkan pengalaman pengguna; 5. Fungsi kanvas dan grafik meningkatkan visualisasi laman web.

Cara menggunakan fungsi MySQL untuk pemprosesan dan pengiraan data Cara menggunakan fungsi MySQL untuk pemprosesan dan pengiraan data Apr 29, 2025 pm 04:21 PM

Fungsi MySQL boleh digunakan untuk pemprosesan dan pengiraan data. 1. Penggunaan asas termasuk pemprosesan rentetan, pengiraan tarikh dan operasi matematik. 2. Penggunaan lanjutan melibatkan menggabungkan pelbagai fungsi untuk melaksanakan operasi kompleks. 3. Pengoptimuman prestasi memerlukan mengelakkan penggunaan fungsi dalam klausa WHERE dan menggunakan GroupBy dan jadual sementara.

Komposer: Pengurus Pakej untuk Pemaju PHP Komposer: Pengurus Pakej untuk Pemaju PHP May 02, 2025 am 12:23 AM

Komposer adalah alat pengurusan ketergantungan untuk PHP, dan menguruskan kebergantungan projek melalui fail komposer.json. 1) parse composer.json untuk mendapatkan maklumat ketergantungan; 2) Mengurangkan kebergantungan untuk membentuk pokok pergantungan; 3) Muat turun dan pasangkan kebergantungan dari Packagist ke Direktori Vendor; 4) Menjana fail komposer.lock untuk mengunci versi ketergantungan untuk memastikan konsistensi pasukan dan kebolehkerjaan projek.

Bagaimana cara menggunakan ciri -ciri jenis di C? Bagaimana cara menggunakan ciri -ciri jenis di C? Apr 28, 2025 pm 08:18 PM

Typetrait digunakan dalam C untuk pemeriksaan dan operasi jenis masa kompilasi, meningkatkan fleksibiliti kod dan keselamatan jenis. 1) Jenis penghakiman dilakukan melalui std :: is_integral dan std :: is_floating_point untuk mencapai pemeriksaan dan output jenis yang cekap. 2) Gunakan std :: is_trivially_copyable untuk mengoptimumkan salinan vektor dan pilih strategi salinan yang berbeza mengikut jenis. 3) Beri perhatian kepada pengambilan keputusan masa kompilasi, jenis keselamatan, pengoptimuman prestasi dan kerumitan kod. Penggunaan tipikal yang munasabah dapat meningkatkan kualiti kod.

Cara mengkonfigurasi set aksara dan peraturan pengumpulan mysql Cara mengkonfigurasi set aksara dan peraturan pengumpulan mysql Apr 29, 2025 pm 04:06 PM

Kaedah untuk mengkonfigurasi set aksara dan kolasi dalam MySQL termasuk: 1. Menetapkan set aksara dan kolasi di peringkat pelayan: setNames'utf8 '; Setcharactersetutf8; SetCollation_Connection = 'UTF8_GENERAL_CI'; 2. Buat pangkalan data yang menggunakan set aksara tertentu dan kolasi: createdataTabaseexample_dbcharactersetutf8collateutf8_general_ci; 3. Nyatakan set aksara dan kolasi semasa membuat jadual: createTableExample_table (idint

Cara menamakan semula pangkalan data di mysql Cara menamakan semula pangkalan data di mysql Apr 29, 2025 pm 04:00 PM

Menamakan semula pangkalan data dalam MySQL memerlukan kaedah tidak langsung. Langkah -langkah adalah seperti berikut: 1. Buat pangkalan data baru; 2. Gunakan mysqldump untuk mengeksport pangkalan data lama; 3. Import data ke dalam pangkalan data baru; 4. Padam pangkalan data lama.

See all articles