最近在研究python,实属小白,总结一下自学是的发生的错误
1.json字符串长得和字典的类型一样但是获取数据是不一样的
#转换为json对象
jsondata=json.loads(content)
data=jsondata['weatherinfo']
这是字符串转化为json对象,获取里面属性
zidian={"a":1,"b":2,"c":3}
value=zidian.get("a")
这是字典获取数据
2.python
定义一个方法是,与java同的是,python想调取这个方法,方法体必须在调取函数的上面,不然会报错
3.object of type 'NoneType' has no len()
刚刚学python,这个问题是因为你获取到的值None,但是呢,这个none值你却进函数处理
4.写入文件时报错UnicodeEncodeError: 'gbk' codec can't encode character '\u2b07' in position 17: illegal multibyte sequence
将
f=open("data.txt",'a+')
修改成
f=open("data.txt",'a+',encoding='utf-8')
出错的原因是网页及python的编码都是utf-8,在写进txt时Windows默认转码成gbk,
遇到某些gbk不支持的字符就会报错。在打开文件时就声明编码方式为utf-8就能避免这个错误。
5.python爬虫报错 AttributeError: 'NoneType' object has no attribute 'text',这是
time=li.find('span',attrs={'class':'sIntro'}).text,整个html中没有span 这种类型
这种情况下try except,说明情况即可:
try:
time=li.find('span',attrs={'class':'sIntro'}).text
print (time)
except:
print ('还没上映')