使用pysolr尝试使用Python3.9将文档添加到solr中,即使只有1或2个字段,也会出现低于错误400的情况。 我在这里使用的字段是动态字段。 连接到solr没有问题
#/usr/bin/python
import pysolr
solr = pysolr.Solr('http://localhost:8080/solr/', always_commit=True)
if solr.ping():
print('connection successful')
docs = [{'id':'123c', 's_chan_name': 'TV-201'}]
solr.add(docs)
res = solr.search('123c')
print(res)
获取以下错误:
connection successful
Traceback (most recent call last):
File "/tmp/test-solr.py", line 8, in <module>
solr.add(docs)
File "/usr/local/lib/python3.9/site-packages/pysolr.py", line 1042, in add
return self._update( File "/usr/local/lib/python3.9/site-packages/pysolr.py", line 568, in
_update
return self._send_request( File "/usr/local/lib/python3.9/site-packages/pysolr.py", line 463, in
_send_request
raise SolrError(error_message % (resp.status_code, solr_message))
pysolr.SolrError: Solr responded with an error (HTTP 400): [Reason: None]
<html><head><meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
<title>Error 400 Unexpected character '[' (code 91) in prolog;
expected '<' at [row,col {unknown-source}]: [1,1]</title>
</head><body><h2>HTTP ERROR 400</h2><p>Problem accessing /solr/update/.
Reason:<pre> Unexpected character '[' (code 91) in prolog;
expected '<' at [row,col {unknown-source}]: [1,1]</pre>
</p><hr><a href="http://eclipse.org/jetty">
Powered by Jetty://9.4.15.v20190215</a><hr/></body></html>
它不适用于iterable
它会起作用的
我建议您查看调试日志(这可能需要您使用
logging.basicConfig()
来启用它们)并测试自己使用的URL。根据您的Solr配置,您的Solr URL可能需要将核心放在末尾(例如http://localhost:8983/solr/mycore
)一般来说,我们得到的大多数类似这样的报告都是关于某人如何配置Solr的奇怪之处。除了调试日志记录之外,我强烈建议查看测试套件,因为它完成了运行Solr所需的一切,并且可以作为比较的方便点:
https://github.com/django-haystack/pysolr
相关问题 更多 >
编程相关推荐