今天搞pyecharts,用了平常强转python对象的方法eval,代码如下;
def Cod19Map():
with open('疫情.txt', 'r', encoding='utf-8') as f:
data = f.read(1024)
print(data)
def main():
Cod19Map()
return 0
if __name__ == '__main__':
main()
结果一个报错给我搞蒙了 为什么蒙了呢?因为之前读写文件里的字典类型数据都是用的这个,代码如下:
def __init__(self):
self.student_list = []
with open('students.data', 'r+', encoding="utf-8") as f:
content = f.read(1024)
if len(content) == 0:
content = '[]'
print(content)
data = eval(content)
self.student_list =\
[Student(i['name'], i['age'], i['phone']) for i in data]
f.close()
students.data的内容如下:
[{'name': '张三', 'age': 1, 'phone': '1001'}, {'name': '李四', 'age': 2, 'phone': '10002'}, {'name': '王五', 'age': 15, 'phone': '10015'}, {'name': '赵六', 'age': 16, 'phone': '10016'}]
于是问题来了,为什么一个可以,一个不可以呢? 我去查了一下,python的文档发现了问题所在,原文如下:
eval(expression[, globals[, locals]])
expression -- 表达式。
globals -- 变量作用域,全局命名空间,如果被提供,则必须是一个字典对象。
locals -- 变量作用域,局部命名空间,如果被提供,可以是任何映射对象。
return:表达式计算结果。
也就是说,后者可以成功是因为read函数读出的字符串包含的是python自带的字典,因此可以返回字典,而json并不是python自己的数据类型 看也是看了,我也分析了json的转化函数: json.dumps,json.loads(1) 操作的是字符串 json.dump,json.load(2) 操作的是文件流 (1)和(2)的相同点: 除了第一个参数(要转换的对象)类型不同,其他所有的参数都相同 最终都是转换成Python对象/Json对象
|