美好的一天! 有一个问题是在python中迭代生成器字典:
sort_dict = {select_keys: {rows: {j: item for item in self.csv_dict.values() if item.get(select_keys) == rows} for rows in keys}}
变量j
必须增加,直到录制vyrozhenie数据为止:
for item in self.csv_dict.values () if item.get (select_keys) == rows}
我是python的新手,所以我为这个愚蠢的问题道歉。我很长一段时间都在争论这个微不足道的问题,但它应该表现出来 - 因为这个问题现在需要解决。
有一个类处理穿孔文件csv:
`import csv
类CSV():
def __init__(self, file_path):
super().__init__()
self.file_path = file_path
self.csv_dict = {}
"""Данный метод парсит переданный в класс CSV файл"""
def parseeCSV(self):
print('\n')
self.getDictCSV()
print(self.getListKeysCSV())
unic_key = self.getUnicValFromCustomKeys('zip')
sort_csv = self.getCsvSortForKeys(unic_key, 'zip')
"""Данный метод создает словарь из переданного в класс CSV файла
Словарь вида {Номер строки(записи){строка(запись)}}
"""
def getDictCSV(self):
i = 0
with open(self.file_path, 'r') as csv_desctiptor:
csv_obj = csv.DictReader(csv_desctiptor)
for csv_dict in csv_obj:
self.csv_dict[i] = csv_dict
i = i + 1
del csv_desctiptor
return True
"""Данный метод возвращает все ключи из словаря self.csv_dict[0]"""
def getListKeysCSV(self):
return dict.keys(self.csv_dict[0])
"""Данный метод возвращает уникальные значения по выбранным полям"""
def getUnicValFromCustomKeys(self, keys):
i = 0
val_key = {}
while i < len(self.csv_dict):
val_key[i] = self.csv_dict[i].get(keys)
unic_val_key = set(val_key.values())
i = i + 1
return unic_val_key
def getCsvSortForKeys(self, keys, select_keys):
#sort_dict = {select_keys: {rows: '' for rows in keys}}
i = 0`
它解析CSV类型的文件:
street,city,zip,state,beds,baths,sq__ft,type,sale_date,price,latitude,longitude
3526 HIGH ST,SACRAMENTO,95838,CA,2,1,836,Residential,Wed May 21 00:00:00 EDT 2008,59222,38.631913,-121.434879
同时他必须做词典类型:
csv_dict[key_select][key_select_val][num-element][element_csv_string]
例如:csv_dict['zip']['95838'][1][3526 HIGH ST,SACRAMENTO,95838,CA,2,1,836,Residential,Wed May 21 00:00:00 EDT 2008,59222,38.631913,-121.434879
提前致谢,我为这些愚蠢的问题道歉。
答案 0 :(得分:1)
请解释一下你的问题。
我无法在您的代码中收集任何j的引用。而且代码似乎错误地构建了。
sort_dict = {select_keys: {rows:
{j: item for j,item in enumerate(self.csv_dict.values())
if item.get(select_keys) == rows} for rows in keys}}
希望有所帮助!