我有一些工作要转换kml文件并插入到mysql数据库中。
我有点搞不懂我的kml文件下有多少个子标记文件夹
这里有一些kml文件
<?xml version="1.0" encoding="UTF-8"?>
<kml xmlns="http://www.opengis.net/kml/2.2" xmlns:gx="http://www.google.com/kml/ext/2.2" xmlns:kml="http://www.opengis.net/kml/2.2" xmlns:atom="http://www.w3.org/2005/Atom">
<Document>
<name>FTTH 5 Cities 60K 20150409.kmz</name>
<open>1</open>
<Folder>
<name>Kebun Jeruk, Jakarta</name>
<Folder>
<name>olt</name>
</Folder>
<Folder>
<name>FEEDER</name>
</Folder>
</Folder>
<Folder>
<name>Kebun Jahe, Jakarta</name>
<Folder>
<name>olt</name>
</Folder>
</Folder>
</Document>
</kml>
这是另一个
<?xml version="1.0" encoding="UTF-8"?>
<kml xmlns="http://www.opengis.net/kml/2.2" xmlns:gx="http://www.google.com/kml/ext/2.2" xmlns:kml="http://www.opengis.net/kml/2.2" xmlns:atom="http://www.w3.org/2005/Atom">
<Document>
<name>FTTH 5 Cities 60K 20150409.kmz</name>
<open>1</open>
<Folder>
<name>Kebun Jeruk, Jakarta</name>
<Folder>
<name>olt</name>
</Folder>
<Folder>
<name>FEEDER</name>
</Folder>
<Folder>
<name>CLUSTER FTTH KEBUN JERUK</name>
</Folder>
</Folder>
</Document>
</kml>
我现在要计算的代码是
$file = $_FILES['fileupload']['tmp_name'];
$xml_file = file_get_contents($file);
$xml = simplexml_load_string($xml_file);
$decodearray = json_decode(json_encode((array)$xml),1);
echo count($decodearray['Document']['Folder']);
需要计数Document->Folder(1st)的子文件夹标记忽略其他
结果我从两个kml文件中得到的是来自另一个样本的2 shold是3。
发布于 2015-06-05 10:30:05
最后,我发现了一个小窍门
$file = 'file.kml';
$xml_file = file_get_contents($file);
$xml = simplexml_load_string($xml_file);
$decodearray = json_decode(json_encode((array)$xml),1);
$nowdatetime = date_create();
$tstamp = date_timestamp_get($nowdatetime);
switch (!isset($decodearray['Document']['Folder'][0])) {
case true:
$docfolder = $decodearray['Document']['Folder'];
break;
case false:
$docfolder = $decodearray['Document']['Folder'][0];
break;
}
echo count($docfolder['Folder']);
简单的切换到索引数组有很大帮助。
https://stackoverflow.com/questions/30651610
复制相似问题