@Shimpanze

XPath: как отсечь пустые текстовые узлы?

Здравствуйте!

Составил выражение собирающее все текстовые узлы:

'//body/div/text()'

но оно собирает и все пустые текстовые узлы. Пытаюсь отсечь их таким образом:

'//body/div/text()[not(normalize-space(text())='')]'


но не в какую не работает.

Подскажите, пожалуйста, как отсечь пустые текстовые узлы?
  • Вопрос задан
  • 313 просмотров
Решения вопроса 1
DevMan
@DevMan
пффф.....
$elements = $xpath->query( '//body/div/* | //body/div/text()' );
foreach( $elements as $element ) {
	// как здесь проверить, текстовый текущий узел или нет?
	if( $element->nodeType == 3 ) {
		// текстовая нода
		$tmp = trim($element->c14n());
		// убираем пустые ноды
		if(! empty($tmp)) {
			echo "<p>" . $tmp . "</p>", PHP_EOL;
		}
	}
	// для всех остальных (не текстовых узлов)
	else {
		echo $element->C14N(), PHP_EOL;
	}
}
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы
YCLIENTS Москва
от 200 000 до 350 000 ₽
Ведисофт Екатеринбург
от 25 000 ₽
ИТЦ Аусферр Магнитогорск
от 100 000 до 160 000 ₽
26 апр. 2024, в 06:46
1500 руб./в час
26 апр. 2024, в 05:31
1000 руб./за проект