xml - 如何格式化solr结果文件?

标签 xml solr

我想格式化 solr 结果页面而不仅仅是一个 xml- 一次仅向用户显示十个结果(一页)并提供下一页或上一页结果的链接。

并添加一些CSS。 我在哪里以及如何做?

请指导我。 提前致谢。

最佳答案

仅作记录(这篇文章很旧)。我在这里发布了一个完整的 XSLT 文件,它以类似于 Google 的方式(带有页码等)格式化 Solr 结果。

您的 Solr 搜索应该具有以下参数: hl=开 hl.fl=内容 开始=0 行=10

<?xml version='1.0' encoding='UTF-8'?>
<xsl:stylesheet version='1.0' xmlns:xsl='http://www.w3.org/1999/XSL/Transform'>
<xsl:output media-type="text/html" encoding="UTF-8"/>

<!-- Variables para el paginador -->
<xsl:variable name="pageNumber" select="(response/result/@start div 10) + 1"/>
<xsl:variable name="numberOfRecords" select="response/result/@numFound"/>
<xsl:variable name="recordsPerPage" select="/response/lst[@name='responseHeader']/lst[@name='params']/str[@name='rows']" />
<xsl:variable name="endPage" select="ceiling(response/result/@numFound div 10)" />
<xsl:variable name="cantPages" select="5" />
<xsl:variable name="queryPura" select="/response/lst[@name='responseHeader']/lst[@name='params']/str[@name='q']" />
<xsl:variable name="query" select="substring-after($queryPura, 'OR ')" />

<xsl:key name="preg" match="lst[@name='highlighting']/lst" use="@name"/>

<xsl:template match="/">
<style>
#resultadoBusqueda em {
font-weight: bold;
font-style: normal;
}
</style>
<table id="resultadoBusqueda">
        <xsl:for-each select="response/result/doc">
        <tr>
                <td style="padding-bottom: 15px;">
                        <div style="font-family: arial; font-size: 16px">
                                <a style="color: #0000cd;" onmouseover="this.style.textDecoration = 'underline';" onmouseout="this.style.textDecoration = 'none';">
                                <xsl:attribute name="href"><xsl:value-of select="str[@name='url']" /></xsl:attribute>
                                        <xsl:if test="not(str[@name='title'])"><xsl:value-of select="str[@name='url']" /></xsl:if>
                                        <xsl:value-of select="str[@name='title']"/>
                                </a>
                        </div>
                        <div style="font-family: arial; color: #000000; font-size: 14px;">
                                <xsl:apply-templates select="key('preg', ./str[@name='id'])" mode="name"/>
                        </div>
                        <div style="font-family: arial; color: #009b00; font-size: 14px;">
                                <xsl:value-of select="str[@name='url']" />
                        </div>
                </td>
        </tr>
        </xsl:for-each>
        <xsl:if test="not(response/result/doc)">
                <h4>No hay ning&#250;n resultado que concuerde con su b&#250;squeda</h4>
        </xsl:if>

    <!-- Paginador -->
    <xsl:if test="response/result/doc">
        <tr>
            <td>
                <xsl:if test="$recordsPerPage &lt; $numberOfRecords">
                    <xsl:if test="$pageNumber &gt; 1">
                        <span style="margin-right: 5px;"><a href="?q={$query}&amp;pag={($pageNumber - 2) * $recordsPerPage}">&lt; Anterior</a> |</span>
                    </xsl:if>
                    <xsl:call-template name="numerosPaginas">
                        <xsl:with-param name="current" select="$pageNumber"/>
                        <xsl:with-param name="max">
                            <xsl:choose>
                                <xsl:when test="(($pageNumber + $cantPages) &gt; $endPage) or ($endPage &lt;= 9)">
                                    <xsl:value-of select="$endPage" />
                                </xsl:when>
                                <xsl:otherwise>
                                    <xsl:value-of select="($pageNumber + $cantPages)" />
                                </xsl:otherwise>
                            </xsl:choose>
                        </xsl:with-param>
                        <xsl:with-param name="number">
                            <xsl:choose>
                                <xsl:when test="(($pageNumber - $cantPages) &lt; 1) or ($endPage &lt;= 9)">
                                    <xsl:value-of select="1" />
                                </xsl:when>
                                <xsl:otherwise>
                                    <xsl:value-of select="($pageNumber - $cantPages)" />
                                </xsl:otherwise>
                            </xsl:choose>
                        </xsl:with-param>

                    </xsl:call-template>
                    <xsl:if test="(($pageNumber ) * $recordsPerPage) &lt; ($numberOfRecords)">
                            <span style="margin-right: 5px;">| <a href="?q={$query}&amp;pag={($pageNumber) * $recordsPerPage}">Siguiente &gt;</a></span>
                    </xsl:if>
                    <span style="margin-right: 5px;">(Resultados encontrados: <xsl:value-of select="$numberOfRecords" />)</span>
                </xsl:if>
            </td>
        </tr>
    </xsl:if>
</table>
</xsl:template>

<xsl:template match="arr/str" mode="name">
        <xsl:value-of select="." disable-output-escaping="yes" />
</xsl:template>

<!-- Numeracion de los paginadores -->
<xsl:template name="numerosPaginas">
    <xsl:param name="current"/>
    <xsl:param name="number"/>
    <xsl:param name="max"/>

    <xsl:choose>
        <xsl:when test="$number = $current">
            <!-- Show current page without a link -->
            <span class="current" style="margin-right: 5px;">
                <xsl:value-of select="$number"/>
            </span>
        </xsl:when>
        <xsl:otherwise>
            <span style="margin-right: 5px;">
                <a href="?q={$query}&amp;pag={($number - 1) * $recordsPerPage}"><xsl:value-of select="$number"/></a>
            </span>
        </xsl:otherwise>
    </xsl:choose>

    <!-- Recursively call the template untill we reach the max number of pages -->
    <xsl:if test="$number &lt; $max">
        <xsl:call-template name="numerosPaginas">
            <xsl:with-param name="current" select="$current"/>
            <xsl:with-param name="number" select="$number+1"/>
            <xsl:with-param name="max" select="$max"/>
        </xsl:call-template>
    </xsl:if>
</xsl:template>


</xsl:stylesheet>

关于xml - 如何格式化solr结果文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2411330/

相关文章:

java - Spring MVC 3 : Returning XML through @ResponseBody

c++ - 使用 boost property_tree 解析 xml 文件并将选定的内容放入 std::map

.net - XSLT:XML 到 HTML 转换 - 无换行符

solr - Solr存储坐标的正确方法

java - 将多个 SOLR 字段合并为一个

solr - 进行详细产品搜索的哪种解决方案?

python - 如何让 PySolr 断开连接?

syntax - 如何在Solr中进行IN查询?

php - 缓存提要或完成的页面?

c# - 在 C# 中构建 XML-RPC Web 服务