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

Реализовать функцию преобразования табличных данных

16.05.2024, 21:14. Показов 832. Ответов 2

Студворк — интернет-сервис помощи студентам
Реализовать функцию преобразования табличных данных. Входная и выходная таблицы заданы в построчной форме, с помощью списков. Заполненные ячейки имеют строковой тип данных. Пустые ячейки имеют значение None.

Округления производятся стандартно, с помощью функции round.

Над входной таблицей провести ряд преобразований:

Удалить пустые столбцы.
Удалить дубли среди строк, оставив только первое вхождение повторяющейся строки в таблицу.
Разбить один из столбцов по разделителю “;”.
Преобразовать содержимое ячеек по примерам.
Примеры табличных преобразований:

Пример 1

Пример 2


код должен выглядеть как то
Python
1
2
3
4
5
6
7
8
def main(table):
    table = filter(len, map(lambda row: list(filter(bool, row)), table))
    table = [[f'{round(float(pct) * 100)}%',
              phone.replace(' ', '').replace('-', ''),
              '-'.join(part[-2:] for part in date.split('.')),
              name.split()[-1]] for pct, phone, date, name in table]
    table = map(list, zip(*table))
    return list(table)
как то так, чтобы когнетивная сложность не превышала

В отправляемом коде на языке программирования Python должна присутствовать функция main и не должно быть какого-либо ввода/вывода. Поддерживается использование модулей только из стандартной библиотеки Python.

вот такой код уже очень сложный
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
def transform_table(table):
    table = remove_empty_columns(table)
    table = remove_duplicate_rows(table)
    table = process_cells(table)
    
    return table
 
def remove_empty_columns(table):
    return [row for row in table if any(cell is not None for cell in row)]
 
def remove_duplicate_rows(table):
    unique_rows = []
    seen_rows = set()
    for row in table:
        row_str = ''.join(str(cell) for cell in row)
        if row_str not in seen_rows:
            seen_rows.add(row_str)
            unique_rows.append(row)
    
    return unique_rows
 
def process_cells(table):
    for row in table:
        for j, cell in enumerate(row):
            if isinstance(cell, str):
                row[j] = process_cell(cell)
            elif cell is None:
                row[j] = 'нет'
            else:
                row[j] = 'да'
    
    return table
 
def process_cell(cell):
    if ';' in cell:
        parts = cell.split(';')
        cell = parts[0]
    if ',' in cell:
        name, surname = cell.split(', ')
        cell = f"{surname} {name}"
    return cell.replace('@', '[at]')
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.05.2024, 21:14
Ответы с готовыми решениями:

Реализовать функцию преобразования табличных данных
Всем привет. Прошу помочь реализовать функцию преобразования табличных данных. Входная и выходная таблицы заданы в построчной форме, с...

Реализовать функцию для преобразования битовых полей
Всем привет! Есть вот такая задача: Реализовать функцию для преобразования битовых полей. В решении необходимо использовать побитовые...

Реализовать функцию для преобразования битовых полей (Python)
В решении необходимо использовать побитовые операции. Примеры результатов вычислений: f(0xa2d136a6) = 0xa626d169 f(0x4c2e73b7)...

2
1956 / 874 / 352
Регистрация: 05.09.2021
Сообщений: 1,387
17.05.2024, 10:44
Лучший ответ Сообщение было отмечено Trashermat как решение

Решение

Trashermat, Выходная таблица содержит список кортежей. И меняется последовательность. Проверьте. Если не пройдет, то можно преобразовать в список списков.
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
table = [
    [None, "Мокобий, Д.Л.;Не выполнено", None, "mokobij19@yandex.ru"],
    [None, "Гофиди, А.А.;Не выполнено", None, "gofidi9@yahoo.com"],
    [None, "Мецодук, А.С.;Выполнено", None, "mezoduk4@rambler.ru"],
    [None, "Мецодук, А.С.;Выполнено", None, "mezoduk4@rambler.ru"],
    [None, "Мецодук, А.С.;Выполнено", None, "mezoduk4@rambler.ru"],
]
 
 
def main(table):
    return list(set(
        (
            line[1].split(",")[0],
            line[-1].replace("@", "[at]"),
            "да" if line[1].split(";")[1] == "Выполнено" else "нет",
        )
        for line in table
    ))
 
 
print(*main(table), sep="\n")
Code
1
2
3
('Мецодук', 'mezoduk4[at]rambler.ru', 'да')
('Мокобий', 'mokobij19[at]yandex.ru', 'нет')
('Гофиди', 'gofidi9[at]yahoo.com', 'нет')
Добавлено через 20 минут
Trashermat, Вот вариант возвращающий список списков, и сохраняющий порядок.
Python
1
2
3
4
5
6
7
8
9
10
11
12
def main(table):
    return [
        list(item)
        for item in {
            (
                line[1].split(",")[0],
                line[-1].replace("@", "[at]"),
                "да" if line[1].split(";")[1] == "Выполнено" else "нет",
            ): None
            for line in table
        }
    ]
Code
1
2
3
['Мокобий', 'mokobij19[at]yandex.ru', 'нет']
['Гофиди', 'gofidi9[at]yahoo.com', 'нет']
['Мецодук', 'mezoduk4[at]rambler.ru', 'да']
1
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5972 / 3734 / 1099
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
17.05.2024, 15:48
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
27
28
29
30
def trixie(lst):
    result = []
    
    rows = len(lst)
    cols = len(lst[0])
    # Удалить пустые столбцы.
    is_delete = [True] * cols
    for j in range(cols):
        for i in range(rows):
            if lst[i][j] is not None:
                is_delete[j] = False
                break
    # print(is_delete)
    lst2 = []
    for i in range(rows):
        row = []
        for j in range(cols):
            if not is_delete[j]:
                row.append(lst[i][j])
        lst2.append(row)
    print(lst2)
 
table = [
    [None, "Мокобий, Д.Л.;Не выполнено", None, "mokobij19@yandex.ru"],
    [None, "Гофиди, А.А.;Не выполнено", None, "gofidi9@yahoo.com"],
    [None, "Мецодук, А.С.;Выполнено", None, "mezoduk4@rambler.ru"],
    [None, "Мецодук, А.С.;Выполнено", None, "mezoduk4@rambler.ru"],
    [None, "Мецодук, А.С.;Выполнено", None, "mezoduk4@rambler.ru"],
]
trixie(table)
Добавлено через 2 минуты
Python
1
2
3
4
5
6
    # Удалить дубли среди строк, оставив только первое вхождение повторяющейся строки в таблицу.
    lst3 = [lst2[0]]
    for row in lst2[1:]:
        if row not in lst3:
            lst3.append(row)
    print(lst3)
Добавлено через 4 минуты
Python
1
2
3
4
5
6
    # Разбить один из столбцов по разделителю “;”.
    lst0 = lst.copy()
    for row in lst0:
        row[1], col2 = row[1].split(';', 1)
        row.insert(2, col2)
    print(*lst0, sep='\n')
Добавлено через 8 минут
Без лишней памяти:
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
    result = lst.copy()
    
    # Разбить один из столбцов по разделителю “;”.
    for row in result:
        row[1], col2 = row[1].split(';', 1)
        row.insert(2, col2)
    print(*result, sep='\n')
    print('----')
    
    # Удалить пустые столбцы.
    rows = len(result)
    j = 0
    while j < len(result[0]):
        is_delete = True
        for i in range(rows):
            if result[i][j] is not None:
                is_delete = False
                break
        if is_delete:
            for i in range(rows):
                result[i].pop(j)
            continue
        j += 1
    print(*result, sep='\n')
    print('----')
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.05.2024, 15:48
Помогаю со студенческими работами здесь

Реализовать функцию преобразования табличных данных
Реализовать функцию преобразования табличных данных. Входная и выходная таблицы заданы в построчной форме, с помощью списков. Заполненные...

Реализовать функцию преобразования табличных данных
Входная и выходная таблицы заданы в построчной форме, с помощью списков. Заполненные ячейки имеют строковой тип данных. Пустые ячейки имеют...

Реализовать на Python функцию преобразования табличных данных
Реализовать функцию преобразования табличных данных. Входная и выходная таблицы заданы в построчной форме, с помощью списков. Заполненные...

Реализовать функцию преобразования матрицы согласно условию
Выполнить задания лабораторной работы №3 в виде функций с входными параметрами, таким образом, чтобы номер выполняемого задания задавался с...

Реализовать методы инициализации данных (конструкторы) и метод преобразования данных в строку toStr
как класс с закрытыми полями, где операции реализуются как методы класса; инкапсулировать поля класса в независимой структуре и в ней...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
YAFU@home — распределённые вычисления для математики. На CPU
Programma_Boinc 20.01.2026
YAFU@home — распределённые вычисления для математики. На CPU YAFU@home — это BOINC-проект, который занимается факторизацией больших чисел и исследованием aliquot-последовательностей. Звучит. . .
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru