django-haystack+solr实现搜索
2012-12-13 00:26
369 查看
前天晚上写了个django-haystack和whoosh结合来实现搜索功能的,今天把solr看了下,下面是实现过程。
1.首先下载solr。http://mirror.bjtu.edu.cn/apache/lucene/solr/3.6.1/apache-solr-3.6.1.zip
下载解压即可,这里要注意下,我用的是solr3.6版本的,所以以下内容都是针对3.6的,至于为什么没用4.0,其实是我还没找到4.0和django-haystack结合起来的方法哈
cd example/
java -jar start.jar
即可启动solr了,可以进入http://localhost:8983/solr/admin/看看效果。
ps. 这里有个地方要注意的,将solr/conf/stopwords.txt改名为stopwords_en.txt,不然会出错的
2.安装pysolr。
sudo pip install pysolr
haystack就不介绍了,看上篇就知道了。
3.修改settings.py
}
4.新建models如下:
5.在blog目录下新建search_indexes.py:
6.新建templates/search/indexes/blog/blog_text.txt:
7.在urls.py中加入(r’^$’, include(‘haystack.urls’)),
8.新建templates/search/search.html:
9.将schema.xml导入:
python manage.py build_solr_schema > /path_to_solr/example/solr/conf/
10.重建索引:
python manage.py rebuild_index
大致流程就这样的。
1.首先下载solr。http://mirror.bjtu.edu.cn/apache/lucene/solr/3.6.1/apache-solr-3.6.1.zip
下载解压即可,这里要注意下,我用的是solr3.6版本的,所以以下内容都是针对3.6的,至于为什么没用4.0,其实是我还没找到4.0和django-haystack结合起来的方法哈
cd example/
java -jar start.jar
即可启动solr了,可以进入http://localhost:8983/solr/admin/看看效果。
ps. 这里有个地方要注意的,将solr/conf/stopwords.txt改名为stopwords_en.txt,不然会出错的
2.安装pysolr。
sudo pip install pysolr
haystack就不介绍了,看上篇就知道了。
3.修改settings.py
<!-- lang: python --> HAYSTACK_CONNECTIONS = { 'default': { 'ENGINE': 'haystack.backends.solr_backend.SolrEngine', 'URL': 'http://127.0.0.1:8983/solr' },
}
4.新建models如下:
<!-- lang: python --> class Blog(models.Model): title = models.CharField(max_length=30) content = models.CharField(max_length=140) created_time = models.DateTimeField(auto_now=True) def __unicode__(self): return self.title
5.在blog目录下新建search_indexes.py:
<!-- lang: python --> import datetime from haystack import indexes from blog.models import Blog class BlogIndex(indexes.SearchIndex, indexes.Indexable): text = indexes.CharField(document=True, use_template=True) title = indexes.CharField(model_attr='title') content = indexes.CharField(model_attr='content') def get_model(self): return Blog def index_queryset(self): return self.get_model().objects.all()
6.新建templates/search/indexes/blog/blog_text.txt:
<!-- lang: html --> {{ object.title }} {{ object.content }}
7.在urls.py中加入(r’^$’, include(‘haystack.urls’)),
8.新建templates/search/search.html:
<!-- lang: html --> <h2>Search</h2> <form method="get" action="."> <table> {{ form.as_table }} <tr> <td> </td> <td> <input type="submit" value="Search"> </td> </tr> </table> {% if query %} <h3>Results</h3> {% for result in page.object_list %} <p> Title: {{ result.object.title }} </p> <p> Content: {{ result.object.content }} </p> {% empty %} <p>No results found.</p> {% endfor %} {% if page.has_previous or page.has_next %} <div> {% if page.has_previous %}<a href="?q={{ query }}&page={{ page.previous_page_number }}">{% endif %}« Previous{% if page.has_previous %}</a>{% endif %} | {% if page.has_next %}<a href="?q={{ query }}&page={{ page.next_page_number }}">{% endif %}Next »{% if page.has_next %}</a>{% endif %} </div> {% endif %} {% else %} {# Show some example queries to run, maybe query syntax, something else? #} {% endif %} </form>
9.将schema.xml导入:
python manage.py build_solr_schema > /path_to_solr/example/solr/conf/
10.重建索引:
python manage.py rebuild_index
大致流程就这样的。
相关文章推荐
- 分享:django-haystack+solr实现搜索
- 分享:django-haystack+solr实现搜索
- django-haystack+solr实现搜索
- Django之站内搜索-Solr,Haystack
- Django开发个人博客网站——19、通过Django Haystack实现搜索功能(上)
- django+haystack+solr 实现网站全文检索
- 使用Solr快速实现Django的全文搜索[转]
- 实现Django的全文检索:Haystack
- Solrflux源码分析-Sql Support within Solr-类Sql的solr搜索实现(2)
- 【案例】solr实现京东搜索功能
- 使用 Apache Lucene 和 Solr 4 实现下一代搜索和分析
- Solr Suggest实现搜索智能提示
- 利用solr实现商品的搜索功能
- 使用 Apache Solr 实现更加灵巧的搜索,第 1 部分: 基本特性和 Solr 模式
- Solr using RankingAlgorithm实现准实时搜索
- solr入门之搜索建议的几种实现方式和最终选取实现思路
- 使用 Apache Solr 实现更加灵巧的搜索,第 1 部分: 基本特性和 Solr 模式
- 利用SOLR搭建企业搜索平台 之八(solr 实现去掉重复的搜索结果,打SOLR-236_collapsing.patch补丁)
- 【django】京东等大型网站的混合搜索是怎么实现的?
- 使用 Apache Lucene 和 Solr 4 实现下一代搜索和分析