简体   繁体   中英

Using php Simple HTML DOM Parser

how do I capture, just the names of the animals.

my zoo.xml

<?xml version="1.0" encoding="UTF-8"?>
<zoo>
<animal id="315" name="Lion"></animal>
<animal id="316" name="Cat"></animal>
</zoo>

I did the test like this, but it returns empty.

edit.

  $html = file_get_html('zoo.xml');
  foreach($html->find('animal') as $animal) {
            $item['name'] = $animal->find('name',0 )->plaintext;
            $animals[] = $item;
        }
        print_r($animals);

result

   Array
(
    [0] => Array
        (
            [name] => 
        )

    [1] => Array
        (
            [name] => 
        )

)

Am I doing the right way?

The animal names are in the attributes, you can use getAttribute :

$html = file_get_html('zoo.xml');
foreach($html->find('animal') as $animal) {
    $animals[] = ['name' => $animal->getAttribute('name')];
}
print_r($animals);

Result:

Array
(
    [0] => Array
        (
            [name] => Lion
        )

    [1] => Array
        (
            [name] => Cat
        )

)

With the help of @KarstenKoop e @Thefourthbird got it.

   $html = file_get_html('zoon.xml');
      foreach($html->find('animal') as $animal) {
                $item['name'] = $animal->name;
                $animals[] = $item;
            }
            print_r($animals);

Thanks

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM