我试图从.Osm文件中提取一些数据。
所以我有这样的事情:
<way id="28747493" visible="true" version="7" changeset="9347177" timestamp="2011-09-19T21:48:11Z" user="Camilo Alvarez" uid="492132">
<nd ref="316077528"/>
<nd ref="316077503"/>
<tag k="highway" v="primary"/>
<tag k="lanes" v="1"/>
<tag k="name" v="Calle 51"/>
<tag k="oneway" v="yes"/>
<tag k="ref" v="Boyacá"/>
</way>
<way id="28747492" visible="true" version="9" changeset="7227086" timestamp="2011-02-08T15:33:22Z" user="dmartinh" uid="314700">
<nd ref="358031212"/>
<nd ref="316077505"/>
<tag k="foot" v="permissive"/>
<tag k="highway" v="footway"/>
<tag k="name" v="Calle 52"/>
</way>
因此,我想提取每个“ ref”并放入名为“ referencia”的表中,并希望为该ref值分配标记名称“ calle 51”。
像这样:
表参考
idnode -------- via
316077528 | Calle 51 |
316077503 | Calle 51 |
358031212 | Calle 52 |
316077505 | Calle 52 |
----------------------
因此,我可以很好地存储“ idnode”值,但不能存储“ via”值。我试图在没有成功的情况下进行前言。
绝对我不知道为什么会这样,我们有一个迭代来获取“ idnode”值,而“ via”则无法存储在一起。
<?php < ? global $referencia;
global $via;
/*
/**
* OSM Overpass API with PHP SimpleXML / XPath
*
* PHP Version: 5.4 - Can be back-ported to 5.3 by using 5.3 Array-Syntax (not PHP 5.4's square brackets)
*/
$dbhost = 'localhost';
$dbuser = 'root';
$dbpass = '';
$conn = mysql_connect($dbhost, $dbuser, $dbpass);
mysql_select_db('map');
if (!$conn)
{
die('Could not connect: ' . mysql_error());
}
echo 'Connected successfully';
$xml = simplexml_load_file("map.osm");
$counter = - 1;
foreach($xml->children() AS $child)
{
$counter++;
if ($child->getName() == 'way')
{
// if($child->getName() == 'node'){
// echo $counter;
$name = "";
$id = "";
$lat = "";
$lon = "";
$name = $child['version'];
$id = $child['id'];
$lat = $child['lat'];
$lon = $child['lon'];
}
foreach($child->children() AS $grandchild)
{
if ($grandchild->getname() == 'nd')
{
$referencia = $grandchild['ref'];
if ($grandchild->getName() == 'tag')
{
if ($grandchild['k'] == 'name')
{
$via = $grandchild['v'];
}
}
mysql_query("INSERT INTO referencia (idnode,via) VALUES ('$referencia','$via')");
}
}
}
?>
提前致谢。
您可以使用SimpleXMLElement :: xpath来获取“ via”和相应的“ idnode”值。例如 :
$raw = <<<EOF
<root>
<way id="28747493" visible="true" version="7" changeset="9347177" timestamp="2011-09-19T21:48:11Z" user="Camilo Alvarez" uid="492132">
<nd ref="316077528"/>
<nd ref="316077503"/>
<tag k="highway" v="primary"/>
<tag k="lanes" v="1"/>
<tag k="name" v="Calle 51"/>
<tag k="oneway" v="yes"/>
<tag k="ref" v="Boyacá"/>
</way>
<way id="28747492" visible="true" version="9" changeset="7227086" timestamp="2011-02-08T15:33:22Z" user="dmartinh" uid="314700">
<nd ref="358031212"/>
<nd ref="316077505"/>
<tag k="foot" v="permissive"/>
<tag k="highway" v="footway"/>
<tag k="name" v="Calle 52"/>
</way>
</root>
EOF;
$xml = simplexml_load_string($raw);
foreach($xml->xpath("//way") AS $way){
$via = $way->xpath("tag[@k='name']/@v")[0];
foreach($way->nd AS $nd){
$idnode = $nd["ref"];
echo $idnode .", ". $via ."<br>";
}
}
输出:
316077528, Calle 51
316077503, Calle 51
358031212, Calle 52
316077505, Calle 52
xpath说明:
//way
选择<way>
XML文档中任何位置的所有元素。
tag[@k='name']
选择属性值等于<tag>
的当前上下文节点的子级。然后从,返回属性。k
name
<tag>
/@v
v
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句