Вот мой XML:
<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:pr="http://www.prconnect.com">
<channel>
<title>Clipping Service</title>
<link>http://www.financialcontent.com</link>
<description>Clipping Service</description>
<pubDate>Sun, 13 Mar 2016 16:38:06 -0400</pubDate>
<language>en-us</language>
<item>
<title><![CDATA[Benton Courier]]></title>
<link>http://business.bentoncourier.com/bentoncourier/news/read/31711961/Featured_National_Park_Series</link>
<source url="http://www.bentoncourier.com">http://www.bentoncourier.com</source>
<description><![CDATA[Featured National Park Series: From Yosemite to Tuzi]]></description>
<pubDate><![CDATA[Thu, 03 Mar 2016 13:55:20 -0500]]></pubDate>
<guid>31711961</guid>
<pr:City>Benton</pr:City>
<pr:State>AR</pr:State>
</item>
Я могу получить заголовок, ссылку, описание, pubDate и т. Д., Но не могу добраться до узлов pr: City или pr: State.
Это позволяет получить доступ к названию города, но в XML не всегда есть город, поэтому увеличение моего счетчика не работает. Я просто хочу получить эти предметы и показать их, если они существуют.
$i=0;
foreach ( $xml->channel->item as $item ) : ?>
<tr>
<td>
<a href="<?php echo $item->link; ?>"title="<?php printf( __( 'Posted %s', 'my-text-domain' ), $item->pubDate ); ?>">
<?php echo $item->title; ?>
</a>
</td>
<td>
<?php printf( __( 'Posted %s', 'my-text-domain' ), $item->pubDate ); ?>
</td>
<td><?php
$item->registerXPathNamespace('pr', 'http://www.prconnect.com');
$city = $item->xpath('//pr:City');
echo $city[$i];
$i++
?></td>
</tr>
<?php endforeach; ?>
Возможно, это простое исправление, но я уже несколько часов пробовал разные варианты.
Для этого было предложено использовать метод children ().
Мне удалось получить доступ к элементам pr: namespace для каждого элемента с помощью следующего цикла.
$pr = $item->children("pr", true);
foreach ($pr as $pr_key => $pr_value) {
echo $pr_key . " = " . $pr_value . "<br />";
}
Задача решена.
Других решений пока нет …