嗨,我有一个xml文件,其中约12,000条记录。我编写的代码,它工作正常,只需要一段时间来解析XML文件并返回内容。有什么办法可以加快这个过程吗?加快xml解析与PHP
我的代码:
<?php
$dom = new DOMDocument();
$dom->load('comics.xml');
foreach ($dom->getElementsByTagName('record') as $entry)
{
$title = $entry->getElementsByTagName('title')->item(0)->textContent;
echo $title;
}
?>
XML文件(在那里只要1演示着联系他们所有的笑):
<?xml version='1.0' encoding='utf-8'?>
<calibredb>
<record>
<id>1</id>
<uuid>991639a0-7cf6-4a34-a863-4aab8ac2921d</uuid>
<publisher>Marvel Comics</publisher>
<size>6109716</size>
<title sort="Iron Man v1 101">Iron Man v1 101</title>
<authors sort="Unknown">
<author>Unknown</author>
</authors>
<timestamp>2012-04-15T18:49:22-07:00</timestamp>
<pubdate>2012-04-15T18:49:22-07:00</pubdate>
<cover>M:/Comics/Unknown/Iron Man v1 101 (1)/cover.jpg</cover>
<formats>
<format>M:/Comics/Unknown/Iron Man v1 101 (1)/Iron Man v1 101 - Unknown.zip</format>
</formats>
</record>
</calibredb>
第1步,找出什么是实际上很慢。关键字:剖析。 – salathe 2012-07-30 22:56:31
你可以尝试xpath并比较结果吗?我认为这可能会更快,但我从未测试过。 – mrok 2012-07-30 22:56:39
使用[XML Parser](http://www.php.net/manual/en/book.xml.php)。它将数据分成块,并且需要手动解析(基于事件),但它比DOMDocument或SimpleXML更有效(没有内部树被构建并卡入内存) – 2012-07-30 22:59:47