solrpy pagnator batch

本文介绍了在使用 Solr 1.4.1 版本时遇到的问题,包括返回 XML 结构的变化导致原有的解析代码无法正常工作。文中详细描述了如何修改 Django-like Paginator 类以适应新的响应格式。
i use solr1.4.1 version,and the return xml is changed, the original return xml is like this 012test ... ... document_idsome test text ... 2 ... some test text ... ... in responseHeader node has params sub node,but the new version(1.4.1),cancle it,so we need hack some code to fix this isuue. so when use the default paginator has one issue, when i invoke it will thrown errors as follows: class SolrPaginator: """ Create a Django-like Paginator for a solr response object. Can be handy when you want to hand off a Paginator and/or Page to a template to display results, and provide links to next page, etc. For example: >>> from solr import SolrConnection, SolrPaginator >>> >>> conn = SolrConnection('http://localhost:8083/solr') >>> response = conn.query('title:huckleberry') >>> paginator = SolrPaginator(response) >>> print paginator.num_pages >>> page = paginator.get_page(5) For more details see the Django Paginator documentation and solrpy unittests. http://docs.djangoproject.com/en/dev/topics/pagination/ """ def __init__(self, result, default_page_size='10'): self.params = {"rows":default_page_size} # lexus modified at 201007 #self.params = result.header['params'] self.result = result self.conn = result._connection if 'rows' in self.params: self.page_size = int(self.params['rows']) elif default_page_size: try: self.page_size = int(default_page_size) except ValueError: raise ValueError('default_page_size must be an integer') if self.page_size < len(self.result.results): raise ValueError('Invalid default_page_size specified, lower ' 'than number of results') else: self.page_size = len(self.result.results) .... 实际调用的例子 #!/usr/bin/env python #encoding=utf8 import solr # create a connection to a solr server s = solr.SolrConnection('http://localhost:8080/solr/core0') # add a document to the index #s.add(id=1, title='Lucene in Action', author=['Erik Hatcher', 'Otis Gospodnetić']) #s.commit() # do a search response = s.query('正品') for hit in response.results: print hit['name'].encode("utf8") print hit['price'] response = s.query('*', facet='true', facet_field='site') for hit in response.results: print hit["name"].encode("utf8") if "brand" in hit: print hit["brand"] else: print "no brand" response = s.query('*') paginator = solr.SolrPaginator(response,default_page_size='1') print type(paginator) print paginator.num_pages

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值