Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
1 / 1 / 0
Регистрация: 09.03.2015
Сообщений: 17

Сравнение и групировка данных

09.03.2015, 20:52. Показов 1517. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дано на входе список:
Code
1
2
3
4
5
6
7
8
9
10
[[reg,city,value],
[reg1,city1,10],
[reg1,city2,20],
[reg1,city3,30],
[reg1,city4,25],
[reg2,city1,20],
[reg2,city2,10],
[reg2,city3,30],
[reg3,city1,15],
[reg3,city2,25]]
и т.д.
надо получить строки:

Code
1
2
3
4
5
6
7
8
reg1:
city1,10
city2,20
city3,30
city4,25
reg2:
city1,20
city2,10
и т.д.

Добавлено через 13 минут
Мой код:

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
#Групировка по повторяющимся данным первого столбика, создаю новый массив
region = []
for line in lines:
    flag = False
    for i in region:
        if str(line[0]) == str(i):
            flag = True
    if not flag:
        region.append(line[0])
 
#Конвертирую числовое значение в число
for r in range(1,len(lines)):
    for c in range(2, len(lines[0])):
        lines[r][c] =  float(lines[r][c])
 
#Группировка всех значений 2 и 3 столбика
def sortbyobl (gines):
    someresult =''
    for r in range(1,len(gines)):
         someresult = someresult+"""
                        {
                            "category": \"""" + str(gines[r][1]) +"\","+"""        
                            "column-1": """+str(gines[r][2])+"""
                         },"""
 
    return someresult
не пойму как сделать, чтоб sortbyobl работало не для всего массива строк а вызывать только для повторяющихся значений...
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.03.2015, 20:52
Ответы с готовыми решениями:

База данных сортировка, а потом групировка
Есть запрос который выводит ближайшие объекты по широте и долготе Select id, lat, lon, name, type, acos(sin(:lat)*sin(radians(lat))...

Групировка
SELECT DISTINCT TargetLocationName, (case when cast(TaskDate as time) < '08:00:00.0000000' then NULL ELSE cast(TaskDate as date) end)...

Групировка объектов
Привет всем! Подскажите пожалуйста, как сгрупировать картинку с формулой в word? Заранее спасибо!

4
Эксперт по компьютерным сетям
 Аватар для Jabbson
5907 / 3359 / 1036
Регистрация: 03.11.2009
Сообщений: 10,008
10.03.2015, 00:47
Лучший ответ Сообщение было отмечено Alex Pancho как решение

Решение

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
lst = [['reg', 'city', 'value'],
       ['reg1', 'city1', '10'],
       ['reg1', 'city2', '20'],
       ['reg1', 'city3', '30'],
       ['reg1', 'city4', '25'],
       ['reg2', 'city1', '20'],
       ['reg2', 'city2', '10'],
       ['reg2', 'city3', '30'],
       ['reg3', 'city1', '15'],
       ['reg3', 'city2', '25']]
 
dct = {}
 
for x in range(1, 10):
    if dct.get(lst[x][0]):
        dct[lst[x][0]] = dct.get(lst[x][0])+lst[x][1:]
    else:
        dct[lst[x][0]] = lst[x][1:]
 
for reg in sorted(dct.keys()):
    print reg + ":"
    for a in range(len(dct[reg])/2):
        print dct[reg].pop(0) + ',' + dct[reg].pop(0)
Code
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
/System/Library/Frameworks/Python.framework/Versions/2.7/bin/python2.7 /Users/json/PycharmProjects/min_arr/minarr.py
reg1:
city1,10
city2,20
city3,30
city4,25
reg2:
city1,20
city2,10
city3,30
reg3:
city1,15
city2,25
 
Process finished with exit code 0
1
224 / 209 / 63
Регистрация: 26.05.2011
Сообщений: 363
10.03.2015, 05:25
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
from itertools import groupby
from operator import itemgetter
 
lst = [['reg', 'city', 'value'],
       ['reg1', 'city1', '10'],
       ['reg1', 'city2', '20'],
       ['reg1', 'city3', '30'],
       ['reg1', 'city4', '25'],
       ['reg2', 'city1', '20'],
       ['reg2', 'city2', '10'],
       ['reg2', 'city3', '30'],
       ['reg3', 'city1', '15'],
       ['reg3', 'city2', '25']]
 
for key, group in groupby(lst[1:], key=itemgetter(0)):
    print("{}:".format(key))
    print("\n".join("{},{}".format(a, b) for _, a, b in group))
1
Эксперт NIX
 Аватар для Marinero
2796 / 2039 / 682
Регистрация: 02.03.2015
Сообщений: 6,509
10.03.2015, 12:27
Python
1
2
3
4
5
6
7
a=''
for x in sorted(lst[1:]):
     if x[0] != a:
         print("{}:\n{},{}".format(x[0],x[1],x[2]))
         a=x[0]
     else:
         print(x[1],x[2],sep=',')
1
Эксперт Python
 Аватар для dondublon
4652 / 2072 / 366
Регистрация: 17.03.2012
Сообщений: 10,182
Записей в блоге: 6
11.03.2015, 11:20
Ещё вариант через collections.defaultdict.
Python
1
2
3
d = defaultdict(list)
for itm in lst:
    d[itm[0]].append((itm[1], itm[2]))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
11.03.2015, 11:20
Помогаю со студенческими работами здесь

Групировка в Listview
Как сгруппировать данные по ученикам находящиеся в одном классе,и вывести в listview? данные для listview беруться из postgres

Групировка LINQ
Всем привет!!! Объясните пожалуйста почему при такой группировке таблицы, как на картинке группировка не происходит. Ведь у меня два...

Массивы, групировка
В целочисленном массиве имеется единственный нулевой элемент, разделяющий его на две части. В частном случае любой из подмассивов может...

групировка записей
Как сгрупировать подрят все записи по фамилиям абонентов и подвести итог общей стоимости их разговоров????????

Групировка в DataGridView
Можно ли сделать объединение колонок в DataGridView как показано на рисунке? Если да, то как...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru