array ( 0 => 'index.php', 1 => 'PHP Manual', ), 'head' => array ( 0 => 'UTF-8', 1 => 'tr', ), 'this' => array ( 0 => 'domxpath.query.php', 1 => 'DOMXPath::query', ), 'up' => array ( 0 => 'class.domxpath.php', 1 => 'DOMXPath', ), 'prev' => array ( 0 => 'domxpath.evaluate.php', 1 => 'DOMXPath::evaluate', ), 'next' => array ( 0 => 'domxpath.registernamespace.php', 1 => 'DOMXPath::registerNamespace', ), 'alternatives' => array ( ), 'source' => array ( 'lang' => 'tr', 'path' => 'reference/dom/domxpath/query.xml', ), ); $setup["toc"] = $TOC; $setup["toc_deprecated"] = $TOC_DEPRECATED; $setup["parents"] = $PARENTS; manual_setup($setup); ?>
(PHP 5, PHP 7, PHP 8)
DOMXPath::query — Belirtilen XPath ifadesini değerlendirir
$ifade
, ?DOMNode $bağlamsal_düğüm
= null
, bool $kaydet
= true
): DOMNodeList
Belirtilen XPath ifade
'sini çözümler.
ifade
Değerlendirilecek XPath ifadesi.
bağlamsal_düğüm
Seçimlik olarak, göreli XPath sorguları yapmak içindir. Öntanımlı olarak sorgular kök elemana göre çözümlenir.
kaydet
Seçimlik kaydet
bağlamsal düğümün otomatik
kütük kaydını önlemek için kullanılabilir.
Belirtilen XPath ifade
'si ile eşleşen tüm
düğümleri içeren bir DOMNodeList nesnesi döner.
Hiçbir eşleşme olmamışsa boş bir DOMNodeList
nesnesi döner.
ifade
bozuksa ya da
bağlamsal_düğüm
geçersizse,
DOMXPath::evaluate() false
döndürür.
Örnek 1 - Tüm İngilizce kitapları listelemek
<?php
$doc = new DOMDocument;
// Fazladan boşlukları korumak istemiyoruz
$doc->preserveWhiteSpace = false;
$doc->load('book.xml');
$xpath = new DOMXPath($doc);
// Sorguyu kök elemandan başlatıyoruz
$query = '//book/chapter/para/informaltable/tgroup/tbody/row/entry[. = "en"]';
$entries = $xpath->query($query);
foreach ($entries as $entry) {
echo "Found {$entry->previousSibling->previousSibling->nodeValue}," .
" by {$entry->previousSibling->nodeValue}\n";
}
?>
Yukarıdaki örneğin çıktısı:
Found The Grapes of Wrath, by John Steinbeck Found The Pearl, by John Steinbeck
İfademizi kısaltmak için bağlamsal_düğüm
bağımsız değişkenini kullanabilirdik:
<?php
$doc = new DOMDocument;
$doc->preserveWhiteSpace = false;
$doc->load('book.xml');
$xpath = new DOMXPath($doc);
$tbody = $doc->getElementsByTagName('tbody')->item(0);
// Sorguyu tbody düğümüne göre yapalım
$query = 'row/entry[. = "en"]';
$entries = $xpath->query($query, $tbody);
foreach ($entries as $entry) {
echo "Found {$entry->previousSibling->previousSibling->nodeValue}," .
" by {$entry->previousSibling->nodeValue}\n";
}
?>