- 浏览: 592545 次
- 性别:
- 来自: 西安
文章分类
最新评论
-
青春依旧:
html5教学哪家强!当然要上华清远见!
深入理解浏览器兼容性模式 -
ashur:
真机智,看得我都笑自己了
js 字符串转dom 和dom 转字符串 -
panghaoyu:
实现一个智能提示功能需要ajax、数据库、jsp/php、算法 ...
solr第一弹 autocomplete(自动补全) -
FakLove:
连线如何删除啊
基于html5 的拖拽连线 -
FakLove:
连线可以再删除吗?
基于html5 的拖拽连线
百度和google中都有文字的自动补全功能,以前项目中也用过实现思路非常简单一般就是extjs 或者jquery 的前台插件通过异步加载数据然后显示,
现在项目的数据源是基于solr所以只有使用solr的autocomplete功能,搜索了很多无数 百度上的 网页根本没有关于solr的自动补全的功能实现,就连关于solr应用性的文章也是比较少的,无奈只好在google上搞了,全都是英文的,尝试了很多的方法都不能使用最后发现是solr api的问题国外的大部分资料都是用得这个写法
private List<Term> query(String q, int limit) { List<Term> items = null; CommonsHttpSolrServer server = null; try { server = new CommonsHttpSolrServer("http://localhost:8983/solr"); } catch(Exception e) { e.printStackTrace(); } // escape special characters SolrQuery query = new SolrQuery(); query.addTermsField("spell"); query.setTerms(true); query.setTermsLimit(limit); query.setTermsLower(q); query.setTermsPrefix(q); query.setQueryType("/terms"); try { QueryResponse qr = server.query(query); TermsResponse resp = qr.getTermsResponse(); items = resp.getTerms("spell"); } catch (SolrServerException e) { items = null; } return items; }
但是不知道是人品问题还是怎么的,我下载的solr1.4 SolrQuery类根本就没有这个addTermsField 和setTermsPrefix 方法,
这是我的下载地址http://mirror.nus.edu.sg/apache//lucene/solr/1.4.1/
solr实现autocomplete功能其实非常简单,仅仅需要下边的这个url就可以实现
fl=id,name&rows=0&q=*:*&facet=true&facet.field=name_auto&facet.mincount=1&facet.prefix=input
我们所要做的就是用solrj的api拼装成这个字符串请求tomcat就ok了
下面是拼装代码
CommonsHttpSolrServer service = new CommonsHttpSolrServer( "http://localhost:8080/solr/targetCore"); List<Term> list = new ArrayList<Term>(); QueryResponse queryResponse = new QueryResponse(); SolrQuery query = new SolrQuery(); // fl=id,name&rows=0&q=*:*&facet=true&facet.field=searchText&facet. // mincount=1&facet.prefix=sony //facet=true&rows=0&fl=id%2Cname&facet.prefix=sony&facet.field=searchText try { query.setFacet(true); query.setRows(0); query.setQuery("*:*"); query.setFacetPrefix("sony"); query.addFacetField("searchText"); System.out.println(query.toString()); queryResponse = service.query(query, METHOD.POST); } catch (Exception e) { // TODO: handle exception e.printStackTrace(); }
返回的内容如下
searchText 中的以sony开头的词都是自动补全的结果,其实这些都是lucene中的term
下边代码使用solrj的api解析文本的过程
CommonsHttpSolrServer service = new CommonsHttpSolrServer( "http://localhost:8080/solr/targetCore"); List<Term> list = new ArrayList<Term>(); QueryResponse queryResponse = new QueryResponse(); SolrQuery query = new SolrQuery(); // fl=id,name&rows=0&q=*:*&facet=true&facet.field=searchText&facet. // mincount=1&facet.prefix=sony //facet=true&rows=0&fl=id%2Cname&facet.prefix=sony&facet.field=searchText try { query.setFacet(true); query.setRows(0); query.setQuery("*:*"); query.setFacetPrefix("索尼"); query.addFacetField("searchText"); System.out.println(query.toString()); queryResponse = service.query(query, METHOD.POST); } catch (Exception e) { // TODO: handle exception e.printStackTrace(); } NamedList<Object> nl = queryResponse.getResponse(); NamedList<Object> nl2 = (NamedList<Object>) nl.get("facet_counts"); NamedList<Object> nl3 = (NamedList<Object>) nl2.get("facet_fields"); NamedList<Object> nl4 = (NamedList<Object>) nl3.get("searchText"); System.out.println(nl4.size()); Iterator<Entry<String, Object>> it = nl4.iterator(); while (it.hasNext()) { Entry<String, Object> entry = it.next(); System.out.println(entry.getKey() + "____" + entry.getValue()); } SolrDocumentList results = queryResponse.getResults(); SolrResult solrResult = new SolrResult();
评论
4 楼
panghaoyu
2017-03-15
实现一个智能提示功能需要ajax、数据库、jsp/php、算法等很多知识,
如果数据量大,还需要特殊优化
一个小功能,花费太大精力很不划算
我使用了92find.c-o-m的搜索框智能提示功能托管服务,
只要一行javascript代码就可以实现百度、淘宝搜索框提示的全部功能
比如:汉字拼音匹配、拼音前缀匹配、模糊搜索、智能容错,还可以自定义提示词汇及其排序权重
花五分钟我的网站就可以部署同百度、淘宝一样强大好用的输入提示功能
同时兼容IE、Firefox、Safari、Chrome、Opera各种浏览器
兼容ios、Android、Windows
如果数据量大,还需要特殊优化
一个小功能,花费太大精力很不划算
我使用了92find.c-o-m的搜索框智能提示功能托管服务,
只要一行javascript代码就可以实现百度、淘宝搜索框提示的全部功能
比如:汉字拼音匹配、拼音前缀匹配、模糊搜索、智能容错,还可以自定义提示词汇及其排序权重
花五分钟我的网站就可以部署同百度、淘宝一样强大好用的输入提示功能
同时兼容IE、Firefox、Safari、Chrome、Opera各种浏览器
兼容ios、Android、Windows
3 楼
飞天奔月
2012-11-20
ak121077313 写道
额 其实我想知道是怎么抓取页面的。
jsoup 你也可以尝试下
2 楼
zha_zi
2011-04-08
数据采集不是我负责的,但是我知道是用heritrix-1.14.3.zip这个东西搞得
1 楼
ak121077313
2011-04-08
额 其实我想知道是怎么抓取页面的。
发表评论
-
HTML5 Server-Sent Events With Java Servlets Example
2014-05-15 15:21 1380Since the dawn of modern web ... -
集群中session同步解决方式
2014-04-06 18:19 1212集群中几种session同步解决方案的比较(转) 在集群中 ... -
Extjs 几个常用控件
2012-11-22 13:01 2324NumberField控件 整数,小数,数字限制 ... -
solr 评分机制
2012-09-28 09:00 2264转自 http://blog.chenlb.com/20 ... -
Flyweight Pattern(享元模式)
2012-03-29 11:43 1443享元模式的特点是,复用我们内存中已存在的对象,降低系 ... -
ThreadPoolExecutor
2011-11-19 10:52 1584ThreadPoolExecutor是 jdk 1.5 ... -
spring mvc 分发器(DispatcherServlet)
2011-11-12 16:58 2778spring mvc 与其他的mvc框架一样都是一种 ... -
编码问题
2011-11-02 15:38 827JSP页面中的pageEncoding和contentTyp ... -
request session servletconfig servletcontext分析
2011-10-14 14:30 2293HttpServletRequest,HttpServle ... -
solr DataimportHanler fileld 出现null
2011-09-08 09:58 1140I'm wo ... -
solr DataimportHanler 效率对比
2011-09-08 09:28 111:用solrj 的api 调用封装SolrInputDocu ... -
solr DataimportHanler
2011-09-03 09:36 1281大多数的应用程序将数据存储在关系数据库、xml文件中 ... -
solr/home是个什么东西
2011-07-19 16:44 1949一直不太明白solr home是个什么东西,每次都 ... -
lucene多索引上的搜索
2011-04-09 15:35 1431上代码 import org.apache.lucene.d ... -
solr第二弹 关于“新蛋” “当当” “京东” 产品搜索的实现假想(1)
2011-04-09 09:39 80资料目前正在整理,很快会贴上去,主要内容 ... -
nutch 更新url.txt无法执行新的抓取
2010-04-19 16:59 1754nutch在使用中经常会修改url.txt中要抓取的目标网站 ... -
tomcat部署的三种方式
2010-04-06 10:19 1443长时间习惯于myeclipse部署tomcat竟然把最基本的 ... -
nutch配置详解
2010-03-11 16:47 3389配置软件: 1、 Java jd ... -
WebLogicDeployableObject' may not be null的问题
2009-11-11 16:23 2564第一次用weblogic 出现了一个很奇怪的问题,按 ...
相关推荐
Solr搜索自动补全是现代电商网站常见的一项功能,它能够显著提升用户体验。当用户在搜索框输入关键词时,系统会根据输入的文字,实时展示一个下拉列表,该列表包含用户可能想要搜索的查询项。这不仅可以引导用户更快...
bass"在内的建议(注意"bass"不一定是第一个词) 内容 支持矩阵 solr-自动完成 索尔 1.6.7.1.0 7.1.0 1.6.6.5.1 6.5.1 1.6.5.2.0 5.2.0 1.6.6.0.1 6.0.1 1.6.6.3.0 6.3.0 建造 您需要 maven 和 JDK 8: $ mvn clean ...
Apache Solr是一款强大的开源搜索引擎,它能够高效地处理和索引大量数据,提供快速的全文检索、 faceting、高亮显示等高级功能。在实际应用中,为了保持搜索结果的实时性,我们往往需要将数据库中的数据实时或定时...
除了基本的全文检索外,Solr还支持拼音搜索和自动补全等功能。例如,可以通过`SpellCheckResponse`类来获取拼写建议。 ```java SolrQuery spellcheckQuery = new SolrQuery("*:*"); spellcheckQuery.set Spellcheck...
- **拼写检查与自动补全(Spellcheck & Autocomplete)**: Solr 提供了拼写纠正功能,以及基于倒排索引的自动补全服务,提升用户输入体验。 - **分布式搜索(Distributed Search)**: 对于大规模数据,Solr 支持...
Solr,全称为Apache Solr,是Apache软件基金会的一个开源项目,主要用来处理全文搜索和企业级的搜索应用。它基于Java,利用Lucene库构建,提供了高效、可扩展的搜索和导航功能。Solr-9.0.0是该软件的最新版本,此...
3. **自动完成(Autocomplete)**:Solr支持实时的搜索建议和自动补全功能,这在构建用户友好的搜索体验时非常关键。实现这一功能通常需要配置`SpellChecker`或`EdgeNgramFilterFactory`,前者用于检查拼写错误,后...
**bbop-widget-solr-autocomplete** 是一个专门针对Solr搜索引擎的JavaScript小部件,用于实现高效的自动完成功能。在Web应用中,这种小部件能够极大地提升用户体验,尤其是在需要进行复杂搜索查询时,用户可以快速...
Solr服务器是Apache Lucene项目的一个子项目,是一款开源的企业级搜索平台,专门用于处理大量文本数据的全文检索、搜索和分析。它基于Java开发,能够处理多种数据源,包括XML、JSON、CSV等,提供了高效、可扩展的...
1. **启动 Tomcat**:启动 Tomcat 服务器,等待 Solr 战包自动部署。 2. **测试连接**:通过浏览器访问 `http://127.0.0.1:8080/solr/`,如果页面显示 Solr 的管理界面,则表示部署成功。 #### 九、中文分词技术...
Suggest组件则为Solr提供了自动补全和提示功能,极大地提升了用户体验。 标题中的“solr7.5_ik分词器,suggest配置源文件”指的是在Solr 7.5版本中使用Ik分词器和Suggest组件进行配置和使用的源文件。Ik分词器是...
5. 拼写建议与自动补全:Solr内置了拼写检查和自动补全功能,可以帮助用户纠正输入错误并提供相关建议,提升用户体验。 6. 多语言支持:Solr具有内置的多种语言分析器,可以处理不同语言的文本,包括中文、英文、...
Apache Solr 是一个开源的全文搜索引擎,由Apache软件基金会维护,是Lucene项目的一部分。它提供了高效、可扩展的搜索和导航功能,广泛应用于企业级的搜索应用中。Solr-8.11.1是该软件的一个特定版本,包含了最新的...
"apache-solr-dataimportscheduler.jar" 是一个专门为Solr设计的扩展包,用于实现自动化的数据增量更新调度。 首先,我们要理解Solr的数据导入过程。Solr使用DataImportHandler(DIH)来从关系型数据库、XML文件或...
Solr,全称为Apache Solr,是一款开源的全文搜索引擎,由Apache软件基金会开发。它提供了高效、可扩展的搜索和导航功能,常被用于大型网站的搜索解决方案。在这个"solr的一个小例子"中,我们将探讨如何搭建一个基础...
6. Solr 的维护方式:Solr 的维护可以通过手动添加或使用 SpringDataSolr 来操作 Solr 索引库,第一次上线的时候可以手动往 Solr 索引库导入一批数据,后期可以自动更新。 7. 全文检索的实现:全文检索是由业务来定...
这使得 Solr 在启动时能够自动加载 ikanalyzer 类库。 3. **配置Schema.xml**:在 Solr 的 schema.xml 文件中,我们需要定义字段类型(FieldType)并指定使用 ikanalyzer。例如,可以创建一个名为 `text_ik` 的字段...
通过正确配置分析器和过滤器,可以处理各种语言的文本,并能够实现复杂的搜索功能,如自动补全、同义词搜索等。 索引与基本数据操作也是Solr中一个关键的环节。索引是将文档数据按照某种逻辑结构存储起来以便于快速...
4. 断词建议:提供拼写纠错和自动补全功能,增强用户体验。 5. 近似搜索:通过模糊匹配,找到与输入关键词相似的搜索结果。 6. 聚类和分类:对搜索结果进行自动聚类,帮助用户发现相关主题。 六、分布式搜索 ...
Solr 数据导入调度器(solr-dataimport-scheduler.jar)是一个专门为Apache Solr 7.x版本设计的组件,用于实现数据的定期索引更新。在理解这个知识点之前,我们需要先了解Solr的基本概念以及数据导入处理...