Solr 中突出显示的工作方式如下:
在带有结果的 XML 响应的开头,您会看到一个“结果”节点,其中包含包含搜索结果的子“doc”节点。像这样的事情:
<doc>
<str name="body">Merge transfer will merge one item with another. The new item can be either from same location or from different location. Merge transfer directions: Open your Paper Tiger Online and select the database. Select item(s) you want to merge except for the one you want to merge the items into, click on Transfer and select Merge. A pop up will be opened asking New Location, once you select the location, the items in the location will be loaded in to the “File to Merge”. Select a file in the “File to Merge” list. Choose whether you want to be reminded to move this file or not Click Merge File Add any additional keywords, notes, action date, change category (if necessary) Click Merge Item button If you chose to be reminded, you'll need to click the Confirm box to confirm the merge, then the merge will happen. (You can also cancel the merge from the Confirm page) </str>
<str name="current-tags"/>
<str name="id">141156</str>
<str name="title">What is a merge transfer? How do I merge files?</str>
</doc>
在带有结果的 XML 响应的末尾,您将看到一个名为“highlighting”的“lst”节点。您会注意到,在每个节点中,您将看到一个子“lst”节点,其名称为您为文档选择的唯一标识符。像这样的事情:
<lst name="141154">
<arr name="body">
<str>Transfers are used to move or <em>merge</em> the items from one location and another location and creating duplicates items in the locations. You might want to move and item from Action to Reference or Archive to an off-site location. You would want to move the item in Paper Tiger to ensure you can find it</str>
</arr>
</lst>
对我来说最简单的方法就是首先遍历“结果”节点并将变量设置为搜索结果的内容。然后,在显示每个项目的循环中,我循环遍历“突出显示”节点并搜索该项目的 ID 以查看是否找到匹配项。如果找到匹配项,我将用突出显示的内容覆盖原始变量的内容。
这样,无论是否找到突出显示的匹配项,您都将显示结果。
cURL_address($curl_url);
$xml = new SimpleXMLElement($data);
foreach ($xml->children() as $node) {
$arr = $node->attributes(); // returns an array
$no_results = FALSE;
//When no results are found
if ($arr["name"] == "response" && $arr["numFound"] == 0) {
echo "No results found for '". $query ."'";
$no_results = TRUE;
}
if ($arr["name"] == "response") {
if ($no_results != TRUE) {
echo "<h4 id=\"search_results\">Search results for '".$query."'</h4>";
}
foreach ($node->doc as $response) {
//Initially set all the variables to the non-highlighted content
$entry_title = $response->str[3];
$entry_body = substr($response->str[0], 0, 300)."…";
$entry_id = $response->str[2];
$entry_tags = $response->str[1];
//logic to see if we need to add ellipsis to start/end of body
$orig_body_beggining = substr($response->str[0], 0, 10);
$orig_body_end = substr($response->str[0], -10);
//Now loop through every highlighted field to see if we have a node that matches the original item's ID
foreach ($xml->lst[1]->lst as $hl_data) {
$arr2 = $hl_data->attributes(); // returns an array
$hl_arr = $arr2["name"];
if ((string)$entry_id == (string)$hl_arr) {
foreach ($hl_data->arr as $hl_content) {
$arr3 = $hl_content->attributes();
//Use a switch to overwrite existing variables if a new one exists that is highlighted
switch($arr3['name']) { // Get attributes as element indices
case 'body':
$f_ellip = NULL;
$l_ellip = NULL;
if ($orig_body_beggining != substr((string)$hl_content->str, 0, 10)) {
$f_ellip = "… ";
}
if ($orig_body_end != substr((string)$hl_content->str, 0, -10)) {
$l_ellip = " …";
}
$entry_body = $f_ellip.(string)$hl_content->str.$l_ellip;
break;
case 'title':
$entry_title = (string)$hl_content->str;
break;
case 'current-tags':
$entry_tags = (string)$hl_content->str;
break;
}
}
}
}
让我知道你的想法!