J'ai quelque chose comme ça:
$url = "http://ws.geonames.org/findNearbyPostalCodes?country=pl&placename=";
$url .= rawurlencode($city[$i]);
$xml = simplexml_load_file($url);
echo $url."\n";
$cityCode[] = array(
'city' => $city[$i],
'lat' => $xml->code[0]->lat,
'lng' => $xml->code[0]->lng
);
Il est supposé télécharger XML à partir de geonames. Si je fais print_r($xml)
je reçois:
SimpleXMLElement Object
(
[code] => Array
(
[0] => SimpleXMLElement Object
(
[postalcode] => 01-935
[name] => Warszawa
[countryCode] => PL
[lat] => 52.25
[lng] => 21.0
[adminCode1] => SimpleXMLElement Object
(
)
[adminName1] => Mazowieckie
[adminCode2] => SimpleXMLElement Object
(
)
[adminName2] => Warszawa
[adminCode3] => SimpleXMLElement Object
(
)
[adminName3] => SimpleXMLElement Object
(
)
[distance] => 0.0
)
Je fais comme vous pouvez voir $xml->code[0]->lat
et il retourne un objet. Comment puis-je obtenir la valeur?
Vous devez convertir un objet simpleXML en chaîne.
$value = (string) $xml->code[0]->lat;
Vous pouvez également utiliser la méthode magique __toString ()
$xml->code[0]->lat->__toString()
Si vous savez que la valeur de l'élément XML est un nombre flottant (latitude, longitude, distance), vous pouvez utiliser (float)
.
$value = (float) $xml->code[0]->lat;
En outre, (int)
pour le nombre entier:
$value = (int) $xml->code[0]->distance;
Pour moi, il est plus facile d'utiliser des tableaux que des objets,
Donc, je convertis un objet Xml,
$xml = simplexml_load_file('xml_file.xml');
$json_string = json_encode($xml);
$result_array = json_decode($json_string, TRUE);
si vous ne connaissez pas la valeur de XML Element, vous pouvez utiliser
$value = (string) $xml->code[0]->lat;
if (ctype_digit($value)) {
// the value is probably an integer because consists only of digits
}
Cela fonctionne lorsque vous devez déterminer si la valeur est un nombre, car (string)
renverra toujours la chaîne et is_int($value)
renvoie false
vous pouvez utiliser le '{}' pour accéder à votre propriété, puis vous pouvez faire ce que vous voulez.
$varName = $xml->{'key'};
De votre exemple, elle est le code
$filePath = __DIR__ . 'Your path ';
$fileName = 'YourFilename.xml';
if (file_exists($filePath . $fileName)) {
$xml = simplexml_load_file($filePath . $fileName);
$mainNode = $xml->{'code'};
$cityArray = array();
foreach ($mainNode as $key => $data) {
$cityArray[..] = $mainNode[$key]['cityCode'];
....
}
}
essayez current($xml->code[0]->lat)
il retourne l'élément sous le pointeur actuel du tableau, qui est 0, ainsi vous obtiendrez une valeur
C’est la fonction qui m’a toujours aidé à convertir les valeurs liées au XML en tableau
function _xml2array ( $xmlObject, $out = array () ){
foreach ( (array) $xmlObject as $index => $node )
$out[$index] = ( is_object ( $node ) ) ? _xml2array ( $node ) : $node;
return $out;
}
vous pouvez convertir un tableau avec cette fonction
function xml2array($xml){
$arr = array();
foreach ($xml->children() as $r)
{
$t = array();
if(count($r->children()) == 0)
{
$arr[$r->getName()] = strval($r);
}
else
{
$arr[$r->getName()][] = xml2array($r);
}
}
return $arr;
}
$codeZero = null;
foreach ($xml->code->children() as $child) {
$codeZero = $child;
}
$lat = null;
foreach ($codeZero->children() as $child) {
if (isset($child->lat)) {
$lat = $child->lat;
}
}
header("Content-Type: text/html; charset=utf8");
$url = simplexml_load_file("http://URI.com");
foreach ($url->PRODUCT as $product) {
foreach($urun->attributes() as $k => $v) {
echo $k." : ".$v.' <br />';
}
echo '<hr/>';
}