Python系列五--发送HTTP请求,问题汇总

Python2 和 Python 3 的语法还是有很多区别的

比如说python2中的 httplib 在python3.5需要怎么改
python3把httplib改了名字,对应的库是http.client

1、包用 import 导入时可以带出来,但是和别的导入的库格式是不一样的(http.client 是带框显示的)

import http.client.png

运行代码时提示 'http' is not a package

提示 **http** 不是一个包.png

原因分析:文件名与包名重名了
解决办法:对文件名重命名

图片.png


2、执行该文件( httprequest )时调用上次的类的方法有错误,单独执行上周的函数是可以正常运行的

 错误信息
 selectone() missing 1 required positional argument: 'condition'
调用上次的类的方法有错误.png
文件单独执行正常运行.png

原因分析:实例化不对(实例化数据库操作)
仔细检查发现上图中 实例化mysql 处理类 缺少括号


3、TypeError: 'NoneType' object is not subscriptable

TypeError: 'NoneType' object is not subscriptable.png

原因分析:表创建后没有插入数据,是一张空表
一不小心,导致变量是空值NoneType而导致此错误的

解决办法很简单,确保你所使用的(字典)变量,里面包含了正确的(键)值。(表中插入数据)


4、AttributeError: 'module' object has no attribute 'xxx'

AttributeError:尝试访问未知的对象属性

AttributeError.png

原因分析:函数调用错误
解决办法:查看源代码中定义的函数,与之匹配


5、TypeError("'int' object is not iterable")

图片.png

修改字段 header_interface 的值为文本格式后继续报错(详见第6点),真的是错误不断啊


6、json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)

最后还是去修改字段的值,改成字典格式的

update case_weatherreport 
set header_interface='{"Accept-Encoding": "gzip, deflate","Accept-Language": "zh-CN"}' 
where id=1;

【总结】
折腾 json 的话,前提要了解json的语法和规则,其次才是用某种语言去处理json。

7、TypeError: tuple indices must be integers or slices, not str

TypeError: tuple indices must be integers or slices, not str.png

原因分析:sql 返回的是tuple,而不是dict,所以不能使用interface_params["key"]的语法

解决办法:返回字典(dict)表示的记录,就要设置cursorclass参数为 pymysql.cursors.DictCursor类
1)在调用connect方法建立连接时设置

 conn = pymysql.connect(host='localhost', port=3306, user='root',
                        passwd='123456', db='zyptest', charset='utf8', 
                        cursorclass=pymysql.cursors.DictCursor)

2)在创建游标时设置

cur = conn.cursor(cursorclass=pymysql.cursors.DictCursor)


8、KeyError:请求一个不存在的字典关键字

根据 keyerror 的定义去核对SQL语句的字段,发现查询出来的字段和参数传的字段不一样,所以报错了

SQL搜索字段和传参值不一致.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,991评论 19 139
  • 转载,觉得这篇写 SQLAlchemy Core,写得非常不错。不过后续他没写SQLAlchemy ORM... ...
    非梦nj阅读 5,499评论 1 14
  • # 第一优先级规则声明: # 除了梦境,每一个意识主进程都必须与一个身体参与的机械进程相匹配,否则结束意识主进程。...
    李洞BarryLi阅读 3,918评论 0 1
  • 《高效能人士的七个习惯》感悟(一) 缘由 最近在看《高效能人士的七个习惯》。一开始看这本书我是拒绝的,因为一看到书...
    hoohack阅读 2,653评论 0 4
  • 临田英章
    liudazhong阅读 159评论 0 1