如何读取五十万个节点的xml文件?


目前二级节点大概有十万个,每个二级节点下面还有四级节点;

我用php,echo出来,特别耗内存。

方法粗暴:


 $xml = simplexml_load_file('example.xml'); 

foreach($xml->Article as $ArticleInfo) 
{
    //读取;
}

主要是想把数据导入到mysql中;
请教有没有便捷的方法?

xml php mysql

marsh元素 9 years, 6 months ago

PHP不熟,但是其它语言都是流式读取XML的方式,PHP应该也有。
查了一下,下面这篇文章好像是流式读取,你可以试试

如何使用PHP处理比较大的XML文件

逆位的塔罗 answered 9 years, 6 months ago

XML Parser 就可以。

通过 xml_set_element_handler() xml_set_character_data_handler() 设置处理方法,读取一段处理一段。具体请看文档。

madao18 answered 9 years, 6 months ago

Your Answer