hashmap için xml - php

2 Cevap php

Böyle bir xml yapısı göz önüne alındığında,

<gesmes:Envelope>
<gesmes:subject>Reference rates</gesmes:subject>
<gesmes:Sender>
<gesmes:name>European Central Bank</gesmes:name>
</gesmes:Sender>
<Cube>
<Cube time="2010-03-26">
<Cube currency="USD" rate="1.3353"/>
<Cube currency="JPY" rate="124.00"/>
<Cube currency="BGN" rate="1.9558"/>
<Cube currency="CZK" rate="25.418"/>
...
...
</Cube>
</Cube>
</gesmes:Envelope>

PHP nasıl bir HashMap veya benzeri bir yapı için saklanan değerler alma hakkında gidebilirsiniz?

D: Şimdi son birkaç saat için bunu yapmak için çalışıyorum ama cant yönetmek olmuştur

O yüzden hiçbir tam solutuins (: D gerçek atama web hizmeti kullanmak Tho, ben sadece ayrıştırma ile şaşırıp) memnun sanırım ödevi. Belki birisi i benim için geçerli olabilecek kadar yapılmış bir xml dosyası için bana kısa bir örnek gösterebilir misiniz?

Teşekkürler

2 Cevap

<gesmes:Envelope> "tüm gerçeği" muhtemelen değildir. gesmes: gibi bir önek bir URI ile ilişkilendirilmesi gerekir. Senin durumunda bu muhtemelen

<gesmes:Envelope
  xmlns:gesmes="http://www.gesmes.org/xml/2002-08-01"
  xmlns="http://www.ecb.int/vocabulary/2002-08-01/eurofxref"
>

Ve şimdi sizinle namespaces .... uğraşmak zorunda

Orada php kullanıcısının simplexml module. Bazı shortcomings when namespaces are involved vardır. Ama yine de ... işte burada:

$s = new SimpleXMLelement(getData());
foreach( $s->Cube as $cubeContainer) {
  foreach( $cubeContainer as $cubeEntry) {
    echo 'time: ', $cubeEntry['time'], "\n";
    foreach( $cubeEntry->Cube as $cubeElement) {  
      echo '  ', $cubeElement['currency'], '=', $cubeElement['rate'], "\n";
    }
  }
}

// now that was easy ...now the fun of having namespaces/prefixes
foreach( $s->children("http://www.gesmes.org/xml/2002-08-01")->subject as $subject) {
  echo 'subject: ', $subject, "\n";
}

foreach( $s->children("http://www.gesmes.org/xml/2002-08-01")->Sender as $sender) {
  foreach( $sender->children("http://www.gesmes.org/xml/2002-08-01")->name as $name) {
    echo 'sender/name: ', $name, "\n";
  }
}



function getData() {
  return '<gesmes:Envelope xmlns:gesmes="http://www.gesmes.org/xml/2002-08-01" xmlns="http://www.ecb.int/vocabulary/2002-08-01/eurofxref">
    <gesmes:subject>Reference rates</gesmes:subject>
    <gesmes:Sender>
      <gesmes:name>European Central Bank</gesmes:name>
    </gesmes:Sender>
    <Cube>
      <Cube time="2010-03-26">
        <Cube currency="USD" rate="1.3353"/>
        <Cube currency="JPY" rate="124.00"/>
        <Cube currency="BGN" rate="1.9558"/>
        <Cube currency="CZK" rate="25.418"/>
      </Cube>
    </Cube>
  </gesmes:Envelope>';
}

baskılar

time: 2010-03-26
  USD=1.3353
  JPY=124.00
  BGN=1.9558
  CZK=25.418
subject: Reference rates
sender/name: European Central Bank

Eğer (ya SimpleXMLElement::xpath veya DOMXPath hangi olarak DOMDocument ile kullanmak istiyorum pointed out by cletus) belirli elemanları / düğümleri bulmak için XPath kullanmak istiyorsanız ilk ad kayıt var.

örneğin

$s = new SimpleXMLelement(getData());
$s->registerXPathNamespace('gesmes', 'http://www.gesmes.org/xml/2002-08-01');
foreach($s->xpath('//gesmes:name[position()=1]') as $n){
  echo $n, "\n";
}

baskılar European Central Bank.

Ve bir XML belgesini ayrıştırmak diğer fonksiyonlar / yöntem vardır. Örneğin XMLReader veya (muhtemelen orijinal arayışı yakın olan "nasıl değerler HashMap için saklanan alma hakkında gitmek [...]?") xml_parse_into_struct()

Kolay yolu DOMDocument sınıfını kullanmaktır. Örneğin:

$src = <<<END
<Cube>
<Cube time="2010-03-26">
<Cube currency="USD" rate="1.3353"/>
<Cube currency="JPY" rate="124.00"/>
<Cube currency="BGN" rate="1.9558"/>
<Cube currency="CZK" rate="25.418"/>
</Cube>
</Cube>
END;

$xml = new DOMDocument;
$xml->loadXML($src);
$cubes = $xml->getElementsByTagName('Cube');
$currencies = array();
foreach ($cubes as $cube) {
  $currency = $cube->getAttribute('currency');
  $rate = $cube->getAttribute('rate');
  if ($currency && $rate) {
    $currencies[$currency] = $rate;
  }
}
print_r($currencies);

Çıktı:

Array
(
    [USD] => 1.3353
    [JPY] => 124.00
    [BGN] => 1.9558
    [CZK] => 25.418
)