当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 5 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : python报错能否这么分析?
帖子发表于 : 2016-10-12 15:46 
头像

注册: 2007-07-14 20:45
帖子: 1307
送出感谢: 68
接收感谢: 38
788---798的代码

代码:
try:
            r = self.session.post(url, data=data, headers=headers)
        except (ConnectionError, ReadTimeout):
            return False
        dic = r.json()
        return dic['BaseResponse']['Ret'] == 0

    def upload_media(self, fpath, is_img=False):
        if not os.path.exists(fpath):
            print '[ERROR] File not exists.'
            return None


报错:
File "/home/wlp2s0/wxBot-master/wxbot.py", line 792, in send_msg_by_uid
dic = r.json()
File "/usr/local/lib/python2.7/dist-packages/requests/models.py", line 826, in json
return complexjson.loads(self.text, **kwargs)
File "/usr/lib/python2.7/json/__init__.py", line 338, in loads
return _default_decoder.decode(s)
File "/usr/lib/python2.7/json/decoder.py", line 366, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
File "/usr/lib/python2.7/json/decoder.py", line 384, in raw_decode
raise ValueError("No JSON object could be decoded")
ValueError: No JSON object could be decoded

这行代码时常报错,可能是什么原因?帮我分析一下


页首
 用户资料  
 
2 楼 
 文章标题 : Re: python报错能否这么分析?
帖子发表于 : 2016-10-12 16:01 
头像

注册: 2011-03-20 13:12
帖子: 4552
地址: 山东省寿光县
系统: Debian
送出感谢: 106
接收感谢: 1009
九天星 写道:
ValueError: No JSON object could be decoded

可能原因 由于多方种种原因 self.session.post(url, data=data, headers=headers) 这一步动作返回错误信息
运行时加上 -i 参数,出错时进入交互模式提示符,检查 self.session.post() 返回给 r 什么内容,r.json() 是不是空的。


_________________
Debian 中文论坛 - forums.debiancn.org
欢迎所有 Debian GNU/Linux 用户


页首
 用户资料  
 
3 楼 
 文章标题 : Re: python报错能否这么分析?
帖子发表于 : 2016-10-12 19:36 
头像

注册: 2007-07-14 20:45
帖子: 1307
送出感谢: 68
接收感谢: 38
好的,我偿试一下。


页首
 用户资料  
 
4 楼 
 文章标题 : Re: python报错能否这么分析?
帖子发表于 : 2016-10-13 11:47 
头像

注册: 2007-07-14 20:45
帖子: 1307
送出感谢: 68
接收感谢: 38
vickycq 写道:
九天星 写道:
ValueError: No JSON object could be decoded

可能原因 由于多方种种原因 self.session.post(url, data=data, headers=headers) 这一步动作返回错误信息
运行时加上 -i 参数,出错时进入交互模式提示符,检查 self.session.post() 返回给 r 什么内容,r.json() 是不是空的。



使用python -i 追踪到的

代码:
File "bot.py", line 106, in <module>
    main()
  File "bot.py", line 102, in main
    bot.run()
  File "/home/wlp2s0/wxBot-master/wxbot.py", line 958, in run
    if self.login():
  File "/home/wlp2s0/wxBot-master/wxbot.py", line 1065, in login
    doc = xml.dom.minidom.parseString(data)
  File "/usr/lib/python2.7/xml/dom/minidom.py", line 1928, in parseString
    return expatbuilder.parseString(string)
  File "/usr/lib/python2.7/xml/dom/expatbuilder.py", line 940, in parseString
    return builder.parseString(string)
  File "/usr/lib/python2.7/xml/dom/expatbuilder.py", line 223, in parseString
    parser.Parse(string, True)
xml.parsers.expat.ExpatError: no element found: line 1, column 0



不过这个报错和上面的报错好像有很大不同。估计不是同一个错误。


页首
 用户资料  
 
5 楼 
 文章标题 : Re: python报错能否这么分析?
帖子发表于 : 2016-10-13 14:26 
头像

注册: 2008-09-18 13:11
帖子: 2950
送出感谢: 1
接收感谢: 495
两个看起来都是一种错误。网络请求失败,返回了空文本,然后不加检查地想用json或xml解析,就挂了


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 5 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:没有注册用户 和 4 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译