Python2 和 Python 3 的语法还是有很多区别的
比如说python2中的 httplib 在python3.5需要怎么改
python3把httplib改了名字,对应的库是http.client
1、包用 import 导入时可以带出来,但是和别的导入的库格式是不一样的(http.client 是带框显示的)
运行代码时提示 'http' is not a package
原因分析:文件名与包名重名了
解决办法:对文件名重命名
2、执行该文件( httprequest )时调用上次的类的方法有错误,单独执行上周的函数是可以正常运行的
错误信息
selectone() missing 1 required positional argument: 'condition'
原因分析:实例化不对(实例化数据库操作)
仔细检查发现上图中 实例化mysql 处理类 缺少括号
3、TypeError: 'NoneType' object is not subscriptable
原因分析:表创建后没有插入数据,是一张空表
一不小心,导致变量是空值NoneType而导致此错误的
解决办法很简单,确保你所使用的(字典)变量,里面包含了正确的(键)值。(表中插入数据)
4、AttributeError: 'module' object has no attribute 'xxx'
AttributeError:尝试访问未知的对象属性
原因分析:函数调用错误
解决办法:查看源代码中定义的函数,与之匹配
5、TypeError("'int' object is not iterable")
修改字段 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
原因分析: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语句的字段,发现查询出来的字段和参数传的字段不一样,所以报错了