1

我正在尝试将 XML 文件中的数据放入数组中,以便可以通过“Magmi”导入它。使用以下代码,我正在处理一个 3.6GB 的 XML 文件。

<?php

$z = new XMLReader;
$z->open('wpcatsub.xml');

$doc = new DOMDocument;

// move to the first <App /> node
while ($z->read() && $z->name !== 'App');

// now that we're at the right depth, hop to the next <App/> until the end of the tree
while ($z->name === 'App')
{
    // either one should work
    //$node = new SimpleXMLElement($z->readOuterXML());
    $node = simplexml_import_dom($doc->importNode($z->expand(), true));

    // now you can use $node without going insane about parsing
    var_dump($node->element_1);

    // go to next <product />
    $z->next('App');
}

?>

当我加载 PHP 文件时,没有出现错误——页面只是空白。我的 XML 数据结构如下...

<App action="A" id="1">
    <BaseVehicle id= "17491"/>
    <Note><![CDATA[License Plate Lamp]]></Note>
    <Qty>.000</Qty>
    <PartType id= "10043"/>
    <Part>W0133-1620896</Part>
    <Product>
        <PartNumber>W0133-1620896</PartNumber>
        <BrandID>OES</BrandID>
        <BrandDescription><![CDATA[Genuine]]></BrandDescription>
        <WorldpacCategoryID>P9032</WorldpacCategoryID>
        <Price>29.85</Price>
        <ListPrice>33.17</ListPrice>
        <Available>Y</Available>
        <OEFlag>OEM</OEFlag>
        <Weight>.10</Weight>
        <Height>.7</Height>
        <Width>4.4</Width>
        <Length>4.4</Length>
        <SellingIncrement>1</SellingIncrement>
        <Popularity>D</Popularity>
        <ImageURL><![CDATA[http://img.eautopartscatalog.com/live/W01331620896OES.JPG]]></ImageURL>
        <ThumbURL><![CDATA[http://img.eautopartscatalog.com/live/thumb/W01331620896OES.JPG]]></ThumbURL>
    </Product>
    <ImageURL><![CDATA[http://img.eautopartscatalog.com/live/W01331620896OES.JPG]]></ImageURL>
    <ThumbURL><![CDATA[http://img.eautopartscatalog.com/live/thumb/W01331620896OES.JPG]]></ThumbURL>
</App>

是否因为文件大小而停滞不前?如果是这样,XMLReader 不应该适用于大型 XML 文件吗?如果不出意外,我还有什么其他选择?

我想如果需要我可以将 XML 数据加载到数据库中,然后使用 SELECT 查询为 MAGMI 导入构建数组。虽然我不确定如何将 XML 文件导入 SQL 数据库。如果需要,我很乐意得到指导。

4

0 回答 0