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

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

09.03.2015, 20:52. Показов 1545. Ответов 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
4653 / 2073 / 366
Регистрация: 17.03.2012
Сообщений: 10,183
Записей в блоге: 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
Ответ Создать тему
Новые блоги и статьи
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru