高亮显示

  1. public SolrDocumentList query(String str) {
  2. SolrQuery query = new SolrQuery(str);
  3. //设置高亮,以下两种方式都行(相当于开启高亮功能)
  4. //query.setHighlight(true);
  5. query.setParam("hl", "true"); //highlighting
  6. //设置高亮显示的请求,高亮显示的内容由该参数决定,但是返回结果还是由SolrQuery决定
  7. //query.setParam("hl.q", "email:zhang@ppstream.com");
  8. /*
  9. * 那些字段高亮显示,可以用空格或者逗号分隔(有一个域的时候正常,两个及以上没测试通过)
  10. * 老版本使用query.addHighlightField("name");query.addHighlightField("description");给多个字段开启高亮功能
  11. */
  12. query.setParam("hl.fl", "name");
  13. //高亮显示字段前后添加html代码
  14. query.setHighlightSimplePre("<font color=\"red\">");
  15. query.setHighlightSimplePost("</font>");
  16. SolrDocumentList list = new SolrDocumentList();
  17. SolrDocument document = null;
  18. QueryResponse response=new QueryResponse();
  19. try {
  20. SolrDocumentList documents = response.getResults();
  21. //第一个Map的键是文档的ID,第二个Map的键是高亮显示的字段名
  22. Map<String, Map<String, List<String>>> map = response.getHighlighting();
  23. for(int i=0;i<documents.size();i++) {
  24. document = documents.get(i);
  25. document.setField("name", map.get(document.getFieldValue("id")).get("name"));
  26. /*document.setField("email", map.get(document.getFieldValue("id")).get("email"));*/
  27. list.add(document);
  28. }
  29. } catch (Exception e) {
  30. }
  31. return list;
  32. }

另外的方法,配置solrconfig.xml

solr是在lucene的基础上做的开发,那么在某些功能的实现上,与lucene也会有相似之处。
 
solr的高亮显示(包括自动摘要),是通过hl这个param,以及其相关变量来实现的,hl是hightlight的简写。lucene中是通过highlighter来操作高亮和摘要的。
 

置高亮的相关属性,是在solrconfig.xml中配置的。在 <requestHandler name="search"
class="solr.SearchHandler"
default="true">下进行配置。solrconfig.xml文件中包含多个requestHandler的标签,但是只有在上述的名
为search的标签中配置才有效。现将配置的案列公布如下:

  1. <requestHandler name="search" class="solr.SearchHandler" default="true">
  2. <!-- default values for query parameters can be specified, these
  3. will be overridden by parameters in the request
  4. -->
  5. <lst name="defaults">
  6. <str name="echoParams">explicit</str>
  7. <int name="rows">10</int>
  8. <str name="df">text</str>
  9. <str name="hl">true</str>
  10. <str name="hl.fl">content</str>
  11. <str name="f.name.hl.fragsize">50</str>
  12. <str name="hl.simple.pre">&lt;font color=&quot;red&gt;</str>
  13. <str name="hl.simple.post">&lt;/font&gt;</str>
  14. </lst>
  15. </requestHandler>

其中,hl是指定是否使用高亮;hl.fl,指定对哪些域进行高亮,对多个域进行高亮的话,好像是用逗号隔
开;f.name.hl.fragsize是指摘要的长度,默认0代表不做摘要。而hl.simple.pre和hl.simple.post则是指定高
亮时显示的格式,默认是<em></em>。详细内容请参见:http://wiki.apache.org/solr/HighlightingParameters。设置完成后,

在solrj中,通过QueryResponse对象的getHighlighting()方法获得。该方法返回
Map<String,Map<String,List<String>>>类型的数据。其中第一个Map中的
key是id,第二个Map中的key是field,List<String>中封装的就是高亮与摘要处理过后的内容了

Map<String, Map<String, List<String>>> map = response.getHighlighting();
 
 通过这个api的方法就可以得到高亮的内容,高亮的内容通过 key 跟索引的document部分关联起来
 
 这个key就是document 的id
 
参数详细说明:

?hl.fl:
用空格或逗号隔开的字段列表。要启用某个字段的highlight功能,就得保证该字段在schema中是stored。如果该参数未被给出,那么就会高
亮默认字段 standard
handler会用df参数,dismax字段用qf参数。你可以使用星号去方便的高亮所有字段。如果你使用了通配符,那么要考虑启用
hl.requiredFieldMatch选项。
 ?hl.requireFieldMatch:
如果置为true,除非该字段的查
询结果不为空才会被高亮。它的默认值是false,意味着它可能匹配某个字段却高亮一个不同的字段。如果hl.fl使用了通配符,那么就要启用该参数。尽
管如此,如果你的查询是all字段(可能是使用copy-field
指令),那么还是把它设为false,这样搜索结果能表明哪个字段的查询文本未被找到
 ?hl.usePhraseHighlighter:
如果一个查询中含有短语(引号框起来的)那么会保证一定要完全匹配短语的才会被高亮。
 ?hl.highlightMultiTerm
如果使用通配符和模糊搜索,那么会确保与通配符匹配的term会高亮。默认为false,同时hl.usePhraseHighlighter要为true。
 ?hl.snippets:
这是highlighted片段的最大数。默认值为1,也几乎不会修改。如果某个特定的字段的该值被置为0(如f.allText.hl.snippets=0),这就表明该字段被禁用高亮了。你可能在hl.fl=*时会这么用。
 ?hl.fragsize:
每个snippet返回的最大字符数。默认是100.如果为0,那么该字段不会被fragmented且整个字段的值会被返回。大字段时不会这么做。
 ?hl.mergeContiguous:
如果被置为true,当snippet重叠时会merge起来。
 ?hl.maxAnalyzedChars:
会搜索高亮的最大字符,默认值为51200,如果你想禁用,设为-1
 ?hl.alternateField:
如果没有生成snippet(没有terms 匹配),那么使用另一个字段值作为返回。
 ?hl.maxAlternateFieldLength:
如果hl.alternateField启用,则有时需要制定alternateField的最大字符长度,默认0是即没有限制。所以合理的值是应该为
 ?hl.snippets * hl.fragsize这样返回结果的大小就能保持一致。
 ?hl.formatter:
一个提供可替换的formatting算法的扩展点。默认值是simple,这是目前仅有的选项。显然这不够用,你可以看看
org.apache.solr.highlight.HtmlFormatter.java 和
solrconfig.xml中highlighting元素是如何配置的。
注意在不论原文中被高亮了什么值的情况下,如预先已存在的em tags,也不会被转义,所以在有时会导致假的高亮。
 ?hl.fragmenter:

个是solr制定fragment算法的扩展点。gap是默认值。regex是另一种选项,这种选项指明highlight的边界由一个正则表达式确定。
这是一种非典型的高级选项。为了知道默认设置和fragmenters (and
formatters)是如何配置的,可以看看solrconfig.xml中的highlight段。
regex 的fragmenter有如下选项:
 ?hl.regex.pattern:正则表达式的pattern
 ?hl.regex.slop:这是hl.fragsize能变化以适应正则表达式的因子。默认值是0.6,意思是如果hl.fragsize=100那么fragment的大小会从40-160.

solr高亮设置以及摘要的更多相关文章

  1. 六、Solr高亮与Field权重

    Solr高亮 原理 做搜索时,高亮是很常见的需求,那么Solr肯定也为高亮提供了支持.先解释下Solr高亮的原理,在我们设置了需要高亮显示的Field之后,查询得到的返回结果会多出来下面的内容: &q ...

  2. Solr高亮与Field权重

    Solr高亮与Field权重   Solr高亮 原理 做搜索时,高亮是很常见的需求,那么Solr肯定也为高亮提供了支持.先解释下Solr高亮的原理,在我们设置了需要高亮显示的Field之后,查询得到的 ...

  3. CUDA代码的高亮设置

    以下基于"WIN7(64位)+Visual Studio 2010+CUDA7.5". 语法高亮除了看起来舒服之外,还可以使用F11寻找函数.变量定义,输入函数的时候也会有相应的提 ...

  4. Tomcat - 设置 HTTP 摘要认证

    在 Tomcat 中设置 HTTP 摘要认证的示例 在 Tomcat 中设置摘要认证与设置基本认证几乎一样,差别在于配置 web.xml 时,<login-config/> 元素在指定认证 ...

  5. vim高亮设置

    vim高亮设置 前提: 查看vim是否完整安装 rpm -qa | grep vim 若完整安装,则会出现如下相关信息 vim-filesystem-7.4.629-5.el6.x86_64 vim- ...

  6. solr 字段设置不存储表示不会进行分词

    solr 字段设置不存储表示不会进行分词

  7. solr高亮及摘要

    修改了原文的一点内容:原文地址为:http://www.cnblogs.com/rainbowzc/p/3680343.html 高亮显示 两种方法: 1.在程序里通过设置query返回高亮信息 pu ...

  8. solr 高亮配置

    solrj中配置: 两种高亮开启设置 // solrParams.setHighlight(true); solrParams.setParam("hl", "true& ...

  9. Solr高亮详解

    hl.fl: 用空格或逗号隔开的字段列表.要启用某个字段的highlight功能,就得保证该字段在schema中是stored.如果该参数未被给出,那么就会高亮默认字段 standard handle ...

随机推荐

  1. NOI.AC NOIP模拟赛 第六场 游记

    NOI.AC NOIP模拟赛 第六场 游记 queen 题目大意: 在一个\(n\times n(n\le10^5)\)的棋盘上,放有\(m(m\le10^5)\)个皇后,其中每一个皇后都可以向上.下 ...

  2. MultiByteToWideChar和WideCharToMultiByte

    CString UTF8ToGB2312(CString str) { int len; // UTF8转换成Unicode len = MultiByteToWideChar(CP_UTF8, 0, ...

  3. Kruskal 模板

    最小生成树指的是在图上面找到权值最小的一棵树,并且保证图上所有的点都在这棵树上. 解决办法:Kruskal 算法(贪心思想) 将边按权值从小到大排序,然后按这个顺序不断连边,直到所有点联通. /** ...

  4. Windows系列之(一):Windows10 上运行Ubuntu Bash

    1. 前言 2016年4月6日,Windows 10 Insider Preview 发布的版本 14316,添加了Ubuntu Bash,在Windows上提供一个Linux环境,可以直接执行Lin ...

  5. 使用 Spring 2.5 注释驱动的 IoC 功能(转)

    基于注释(Annotation)的配置有越来越流行的趋势,Spring 2.5 顺应这种趋势,提供了完全基于注释配置 Bean.装配 Bean 的功能,您可以使用基于注释的 Spring IoC 替换 ...

  6. Go 语言中的 new() 和 make()的区别

    本文是看了文章之后的心得. 在此感谢. 概述 Go 语言中的 new 和 make 一直是新手比较容易混淆的东西,咋一看很相似.不过解释两者之间的不同也非常容易. 他们所做的事情,和应用的类型也不相同 ...

  7. MySQL查询报错 ERROR: No query specified

    今天1网友,查询报错ERROR: No query specified,随后它发来截图. root case:查询语法错误 \G后面不能再加分号;,由于\G在功能上等同于;,假设加了分号,那么就是;; ...

  8. Linux内存管理学习1 —— head.S中的段页表的建立

    作者 彭东林 pengdonglin137@163.com 平台 TQ2440 Qemu+vexpress-ca9 Linux-4.10.17 概述 在Linux自解压完毕后,开始执行arch/arm ...

  9. 初识GRUNT

    什么是GRUNT? 基于任务的命令行工具.能做的事包括: ● 验证html,css, javascript● 压缩css, javascript● 编译CoffeeScript, TypeScript ...

  10. HTML5之SVG

    1.背景 SVG是Scalable Vector Graphics的缩写,意为可缩放矢量图形.1998年,万维网联盟成立了一个工作组,研发一种通过 XML来表现矢量图形的技术——SVG!由于SVG也是 ...