如何在XML中搜索? (PHP)

How to search in XML? (PHP)

我正在开发一个 word 应用程序。我正在尝试从 XML 获取值。我的目标是获取单词的第一个和最后一个字母。你能帮帮我吗?

<!--?xml version='1.0'?-->
<Letters>
    <Letter category='A'>
        <FirstLetter>
            <Property>First letter is A.</Property>
        </FirstLetter>
        <LastLetter>
            <Property>Last letter is A.</Property>
        </LastLetter>
    </Letter>
    <Letter category='B'>
        <FirstLetter>
            <Property>First letter is B.</Property>
        </FirstLetter>
        <LastLetter>
            <Property>Last letter is B.</Property>
        </LastLetter>
    </Letter>
    <Letter category='E'>
        <FirstLetter>
            <Property>First letter is E.</Property>
        </FirstLetter>
        <LastLetter>
            <Property>Last letter is E.</Property>
        </LastLetter>
    </Letter>
</Letters>

PHP代码:

<?php
$word = "APPLE";
$alphabet = "ABCÇDEFGĞHIİJKLMNOÖPQRSŞTUÜVWXYZ";
$index = strpos($alphabet, $word);
$string = $xml->xpath("//Letters/Letter[contains(text(), " . $alfabe[$rakam] . ")]/FirstLetter");
echo "<pre>" . print_r($string, true) . "</pre>";

该字母位于名为 'category' 的属性中。

$word = "APPLE";

// bootstrap DOM
$document = new DOMDocument();
$document->loadXML($xml);
$xpath = new DOMXpath($document);

// get first and last letter
$firstLetter = substr($word, 0, 1);
$lastLetter = substr($word, -1);

// fetch text from property elements
var_dump(
  $xpath->evaluate(
     "string(/Letters/Letter[@category = '$firstLetter']/FirstLetter/Property)"   
  ),
  $xpath->evaluate(
     "string(/Letters/Letter[@category = '$lastLetter']/LastLetter/Property)"   
  )
);

或者在 SimpleXML 中

$word = "APPLE";

$letters = new SimpleXMLElement($xml);

$firstLetter = substr($word, 0, 1);
$lastLetter = substr($word, -1);

// SimpleXML does not allow for xpath expression with type casts
// So validation and cast has to be done in PHP
var_dump(
  (string)($letters->xpath(
    "/Letters/Letter[@category = '$firstLetter']/FirstLetter/Property"
  )[0] ?? ''),
  (string)($letters->xpath(
    "/Letters/Letter[@category = '$lastLetter']/LastLetter/Property"
  )[0] ?? '')
);