Группировка по значению ключевого свойства в списке python - PullRequest
0 голосов
/ 05 февраля 2019

У меня есть orig список кортежей, который включает в себя dict & text значения.

orig = [({'x': 28.346, 'y': 19},'Text0'),
 ({'x': 109.726, 'y': 19},'Text1'),
 ({'x': 147.776, 'y': 19},'Text2'),
 ({'x': 153.606, 'y': 24}, 'Text3'),
 ({'x': 452.788, 'y': 24}, 'Text4'),
 ({'x': 504.168, 'y': 34}, 'Text5'),
 ({'x': 527.768, 'y': 34}, 'Text6'),
 ({'x': 533.598, 'y': 45},'Text7'),
 ({'x': 64.291, 'y': 55},'Text8'),
 ({'x': 98.623, 'y': 55},'Text9')]

, и я хочу отфильтровать группу из key='y' в которой можно было бы перечислить еев соответствии с уникальными значениями в y.Примерно так:

res = [
      [({'x': 28.346, 'y': 19},'Text0'),
         ({'x': 109.726, 'y': 19},'Text1'),
         ({'x': 147.776, 'y': 19},'Text2')],
     [({'x': 153.606, 'y': 24}, 'Text3'),
         ({'x': 452.788, 'y': 24}, 'Text4')],
     [({'x': 504.168, 'y': 34}, 'Text5'),
         ({'x': 527.768, 'y': 34}, 'Text6')],
     [({'x': 533.598, 'y': 45},'Text7')],
     [({'x': 64.291, 'y': 55},'Text8'),
         ({'x': 98.623, 'y': 55},'Text9')]]

Ответы [ 2 ]

0 голосов
/ 05 февраля 2019

Двухлинейное решение с использованием itertools.groupby и list comprehension:

from itertools import groupby
# group by the input orig with a key of dict "y" and then take it in a list of list comprehension
print ([[x for x in v] for k, v in groupby(orig, key= lambda x: x[0]["y"])])

Результат:

[[({'x': 28.346, 'y': 19}, 'Text0'), ({'x': 109.726, 'y': 19}, 'Text1'), ({'x': 147.776, 'y': 19}, 'Text2')], [({'x': 153.606, 'y': 24}, 'Text3'), ({'x': 452.788, 'y': 24}, 'Text4')], [({'x': 504.168, 'y': 34}, 'Text5'), ({'x': 527.768, 'y': 34}, 'Text6')], [({'x': 533.598, 'y': 45}, 'Text7')], [({'x': 64.291, 'y': 55}, 'Text8'), ({'x': 98.623, 'y': 55}, 'Text9')]]

Надеюсь, это имеет значение:)

0 голосов
/ 05 февраля 2019

Если вы используете numpy, это будет немного проще.

import numpy as np
orig = [({'x': 28.346, 'y': 19}, 'Text0'),
        ({'x': 109.726, 'y': 19}, 'Text1'),
        ({'x': 147.776, 'y': 19}, 'Text2'),
        ({'x': 153.606, 'y': 24}, 'Text3'),
        ({'x': 452.788, 'y': 24}, 'Text4'),
        ({'x': 504.168, 'y': 34}, 'Text5'),
        ({'x': 527.768, 'y': 34}, 'Text6'),
        ({'x': 533.598, 'y': 45}, 'Text7'),
        ({'x': 64.291, 'y': 55}, 'Text8'),
        ({'x': 98.623, 'y': 55}, 'Text9')]


input_array = np.array([val[0]['y'] for val in orig])
out_array = [np.where(input_array == element)[0].tolist() for element in np.unique(input_array)]
res = [[orig[i] for i in ind_arr] for ind_arr in out_array]
print(res)

Вывод:

[[({'x': 28.346, 'y': 19}, 'Text0'),
  ({'x': 109.726, 'y': 19}, 'Text1'),
  ({'x': 147.776, 'y': 19}, 'Text2')],
 [({'x': 153.606, 'y': 24}, 'Text3'),
    ({'x': 452.788, 'y': 24}, 'Text4')],
 [({'x': 504.168, 'y': 34}, 'Text5'),
    ({'x': 527.768, 'y': 34}, 'Text6')],
 [({'x': 533.598, 'y': 45}, 'Text7')],
 [({'x': 64.291, 'y': 55}, 'Text8'),
    ({'x': 98.623, 'y': 55}, 'Text9')]]
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...