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

TA貢獻1856條經驗 獲得超17個贊
DictReader 是懶惰的。實際上把它變成一個列表并返回它,這樣文件就可以在它仍然打開的時候被讀取。
def myfunc():
fileName: some file on my system
with open(fileName) as csv:
return list(csv.DictReader(csv, delimiter=','))

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 中的列名替換列名。
添加回答
舉報