今天搞pyecharts,用了平常强转python对象的方法eval,代码如下;
def Cod19Map():
# 获取数据
with open('疫情.txt', 'r', encoding='utf-8') as f:
data = f.read(1024)
# data = eval(data)
print(data)
def main():
# OfficeDemo()
Cod19Map()
return 0
if __name__ == '__main__':
main()
结果一个报错给我搞蒙了
为什么蒙了呢?因为之前读写文件里的字典类型数据都是用的这个,代码如下:
def __init__(self):
self.student_list = []
with open('students.data', 'r+', encoding="utf-8") as f:
# print(f.read(1024))
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对象

博主在使用Python的eval函数处理来自文件(疫情.txt和students.data)的数据时遇到问题,尽管之前文件数据解析正常,但这次遇到错误。文章揭示了问题在于eval对不同类型数据处理的差异,以及json数据不是Python内置字典导致的解析区别。
938

被折叠的 条评论
为什么被折叠?



