0

我有这个从 XML 获取值并创建多维数组的函数。

function esummary_query($db, $id) { 
    $context = stream_context_create(array(
      'http'=>array(
        'user_agent' => 'Mozilla/5.0 (Windows NT 5.1) AppleWebKit/536.11 (KHTML, like Gecko) Chrome/20.0.1132.57 Safari/536.11'
       )
    ));

    $xml = file_get_contents('http://eutils.ncbi.nlm.nih.gov/entrez/eutils/esummary.fcgi?db=' . $db . '&id=' . $id, FALSE, $context);

    $xml_file = simplexml_load_string($xml);
    $results2 = array();
      $c=0;
    foreach ( $xml_file->DocSum as $items ) {
        $results2[$c]['id'] = $items->Id;
        $authors = $xml_file->xpath("//Item[@Name='Author']");
        foreach ($authors as $author) {
            $results2[$c]['authors'][] = $author;
        }
          $c++;
    }
    return $results2;
}

但这会在每次读取 DocSum 时获取 name="Author" 的所有项目。我知道会发生这种情况,因为我选择 name="authors" 的所有项目,但如果我把 $xml_file->xpath("/Item[@Name='Author']") 或 $items->xpath( “/Item[@Name='Author']”)它不起作用。

这是XML

我该怎么做?

谢谢!

4

1 回答 1

0

//DocSum/Id[text()="24214944"]/..//Item[@Name="Author"]返回以 24214944 作为 id 的 DocSum 的作者列表。从中扩展,您可以动态构建 xpath 查询:

$results2[$c]['id'] = $items->Id;
$authors = $xml_file->xpath('//DocSum/Id[text()="' . $items->Id . '"]/..//Item[@Name="Author"]');
foreach ($authors as $author) {
    $results2[$c]['authors'][] = $author;
}
于 2013-11-16T00:24:39.290 回答