为了账号安全,请及时绑定邮箱和手机立即绑定

Python,使用从函数返回的字典列表

Python,使用从函数返回的字典列表

动漫人物 2023-06-06 16:14:34
我试图返回字典列表,然后在函数外使用它: def myfunc():     fileName: some file on my system     with open(fileName) as csv1:         dataDict = csv.DictReader(csv1, delimiter=',')         return dataDict    但是当我调用 t 函数时,出现错误“ValueError:已关闭文件的 I/O 操作”。myDict = myfunc()for row in myDict:    print(row)我应该如何声明和使用字典列表?返回字典后,我还需要访问其字段名。非常感谢任何提示或帮助。
查看完整描述

3 回答

?
呼唤远方

TA贡献1856条经验 获得超11个赞

该with语句自动关闭文件。当您尝试通过语句外的 DictReader 访问数据时with,DictReader 无法访问已关闭的文件,因此您会得到 IOError。


您可以通过在从函数返回之前将文件中的行收集到列表中来解决这个问题:


 def myfunc():

     fileName: some file on my system

     with open(fileName) as csv1:

         dataDict = csv.DictReader(csv1, delimiter=',')

         list_of_dicts = list(datadict)

         return list_of_dicts


查看完整回答
反对 回复 2023-06-06
?
慕慕森

TA贡献1856条经验 获得超17个赞

DictReader 是懒惰的。实际上把它变成一个列表并返回它,这样文件就可以在它仍然打开的时候被读取。


def myfunc():

     fileName: some file on my system

     with open(fileName) as csv:

         return list(csv.DictReader(csv, delimiter=','))


查看完整回答
反对 回复 2023-06-06
?
白板的微信

TA贡献1883条经验 获得超3个赞

你可以将它复制到另一个变量中并返回它......


 def myfunc():

     fileName: some file on my system

     mydict = {}

     with open(fileName) as f: 

         for row in csv.DictReader(f, delimiter=','):

             mydict[row['first_column']] = row['second_column'] + row['third_column']


     return mydict  


用 csv 中的列名替换列名。


查看完整回答
反对 回复 2023-06-06
  • 3 回答
  • 0 关注
  • 136 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信