生成器字典中的迭代变量

时间:2016-10-20 13:49:10

标签: python dictionary iterator

美好的一天! 有一个问题是在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

提前致谢,我为这些愚蠢的问题道歉。

1 个答案:

答案 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}}

希望有所帮助!