簡體   English   中英

如何在不使用列表理解的情況下從csv文件創建詞典列表

[英]How to create a list of dictionaries from a csv file without list comprehension

輸出必須是這樣的:

[{'id': '1', 'first_name': 'Heidie','gender': 'Female'}, {'id': '2', 'first_name': 'Adaline', 'gender': 'Female'}, {...}

運行此要求的代碼段有效。

with open('./test.csv', 'r') as file_read:
   reader = csv.DictReader(file_read, skipinitialspace=True)
   listDict = [{k: v for k, v in row.items()} for row in reader]
   print(listDict)

但是,我不明白上面這段代碼的一些要點:

  1. 列表理解: listDict = [{k: v for k, v in row.items()} for row in reader]
    • python如何解釋呢?
    • 編譯器如何始終將標頭( idfirst_namegender )及其值組合在一起?
    • 如何將這個代碼執行嵌套for

我讀了這些答案,但我仍然不明白:

我的csv文件:

id,first_name,last_name,email,gender
1,Heidie,Philimore,hphilimore0@msu.edu,Female
2,Adaline,Wapplington,awapplington1@icq.com,Female
3,Erin,Copland,ecopland2@google.co.uk,Female
4,Way,Buckthought,wbuckthought3@usa.gov,Male
5,Adan,McComiskey,amccomiskey4@theatlantic.com,Male
6,Kilian,Creane,kcreane5@hud.gov,Male
7,Mandy,McManamon,mmcmanamon6@omniture.com,Female
8,Cherish,Futcher,cfutcher7@accuweather.com,Female
9,Dave,Tosney,dtosney8@businesswire.com,Male
10,Torr,Kiebes,tkiebes9@dyndns.org,Male

您的清單理解:

listDict = [{k: v for k, v in row.items()} for row in reader]

等於:

item_list = []

#go through every row
for row in reader:
    item_dict = {}
    #in every row go through each item
    for k,v in row.items():
        #add each items k,v to dict.
        item_dict[k] = v
    #append every item_dict to item_list
    item_list.append(item_dict)

print(item_list)

編輯(更多說明):

#lets create a list
list_ = [x ** 2 for x in range(0,10)]
print(list_)

這將返回:

[0,1,4,9,16,25,36,49,64,81]

您可以這樣寫:

 list_ = []
 for x in range(0,10):
     list_.append(x ** 2)

因此,在該示例中,您讀了“向后”

現在假設下一個:

#lets create a list
list_ = [x ** 2 for x in range(0,10) if x % 2 == 0]
print(list_)

這將返回:

[0,4,16,36,64]

您可以這樣寫:

 list_ = []
 for x in range(0,10):
     if x % 2 == 0:
         list_.append(x ** 2)

因此,這並不是100%倒退,但應該是合乎邏輯的。 希望這對您有所幫助!

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM