lucene 基于索引的查询

                                               lucene 基于索引的查询

根据title模糊查询:

根据上一篇文章我们将索引生成到了indexpack 文件夹中:
public String searchInfo(HttpServletRequest request) throws CorruptIndexException, IOException,
            InvalidTokenOffsetsException, ParseException {
  //索引文件保存的路径
        String indexpackUrl = InfoService.class.getResource("/").getPath().replaceFirst("/", "")
                .replaceAll("WEB-INF/classes/", "")
                + "static/indexpack";
//读取索引文件
        IndexReader indexReader = IndexReader.open(new SimpleFSDirectory(new File(indexpackUrl)));
        IndexSearcher indexSearch = new IndexSearcher(indexReader);   
     // 搜索页面传入的参数
        String title = request.getParameter("title");
       
        String content = request.getParameter("content");
        List<String> fieldsList = new ArrayList<String>();
        fieldsList.add("title");
        // 单个关键字查询器匹配
        // Query query=new TermQuery(new Term("title",title));
        // 模糊查查询器
        // FuzzyQuery query2=new FuzzyQuery(new
        // Term("title","*"+title+"*"),0.1f);
       // WildcardQuery query3 = new WildcardQuery(new Term("title", title));

         //多个查询组合用到的  可以and 多个query
        BooleanQuery booleanQueryHighlighter = new BooleanQuery();
        String[] fields = (String[]) fieldsList.toArray(new String[fieldsList.size()]);
        //前面讲了多种查询器 这种方式为统一的  不用自己判断使用哪种查询器 解决了我的中文搜索不到的问题
        QueryParser parser = new MultiFieldQueryParser(Version.LUCENE_30, fields,
                new StandardAnalyzer(Version.LUCENE_30));

        Query query4 = parser.parse(title);
        // 一定包含 Occur.MUST
        booleanQueryHighlighter.add(query4, Occur.MUST);
        
       //查询的结果
        TopDocs topdocs = indexSearch.search(booleanQueryHighlighter, null, 10);
        StringBuilder builder = new StringBuilder();
        // 高亮显示
        Highlighter highLighter = null;
        SimpleHTMLFormatter fomater = new SimpleHTMLFormatter("<font color='red'>", "</font>");
        highLighter = new Highlighter(fomater, new QueryScorer(booleanQueryHighlighter));
        highLighter.setTextFragmenter(new SimpleFragmenter(Integer.MAX_VALUE));


        for (ScoreDoc doc : topdocs.scoreDocs) {
            Document document = indexSearch.doc(doc.doc);
            TokenStream tokenStream = new StandardAnalyzer(Version.LUCENE_30).tokenStream("token",
                    new StringReader(document.get("title")));
            String str = highLighter.getBestFragment(tokenStream, document.get("title"));
            builder.append(str);
        }
       
        return builder.toString();
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值