0 / 0 / 0
Регистрация: 29.10.2024
Сообщений: 4

Формулы Excel и Python

29.10.2024, 05:58. Показов 2557. Ответов 6

Студворк — интернет-сервис помощи студентам
Приветствую вас, о мудрейшие из мудрейших!

Прощу у вас помощи, так как уже стал терять уверенность и значимость своей деятельности.
Дело в том, что я недавно (около года) стал изучать Python. Не для развлечений, а для автоматизации своей рабочей рутины. И вот я захотел попробовать написать код для автоматизации применения функции ВПР Excel в нужных Excel файлах. Но столкнулся с проблемой того, что результаты применения функции в столбце сохраняются в виде формулы (=ВПР(E2; $Sheet1.E:E; 1; 0)). С помощью chatgpt удалось решить данный вопрос, но только на Windows посредством библиотеки pywin32. Однако, ирония заключается в том, что мне приходится на работе сидеть на AlterOS (он же russian Linux) и работать исключительно на Python 3.6 , по естественным причинам pywin32 не работает. Испробовал множество вариантов с pandas и openpyxl, но бестолку. О мудрейшие, я прощу вашей помощи в разрешении моего вопроса...

Прилагаю последнею версию когда, где я предполагал вариант создания отдельной страницы, копирования в него в качестве значения всей таблицы, удаления старой страницы и переименование новой страницы - в старую, но тоже бестолку...

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
import pandas as pd
from openpyxl import Workbook, load_workbook
 
# Чтение данных из Sheet2
wb = load_workbook('new_files/file_1.2.xlsx')
sheet2 = wb['Sheet2']
data = [[cell.value for cell in row] for row in sheet2.rows]
 
# Создание DataFrame
df = pd.DataFrame(data)
 
# Создание нового листа и запись данных
wb.create_sheet('Sheet3')
sheet3 = wb['Sheet3']
for i, row in enumerate(df.values.tolist(), start=1):
    for j, value in enumerate(row, start=1):
        sheet3.cell(row=i, column=j).value = value
 
# Удаление оригинального Sheet2
wb.remove(sheet2)
 
# Переименование нового листа в Sheet2
sheet3.title = 'Sheet2'
 
# Сохранение рабочей книги
wb.save('new_files/file_1.3.xlsx')
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.10.2024, 05:58
Ответы с готовыми решениями:

Вписать данные из одного файла excel в другие excel, word файлы python
Здравствуйте. Надо считать данные с Excel файла(с этим разобрались). Затем, надо вписать их в различные excel и word файлы(каждый из них...

Формулы Python
Подскажите, как в маткаде вообще получилось S0? Там не определена f вообще нигде. пытаюсь переписать на питон, кое-как пытаюсь...

Формулы и математические выражения Python
Здравствуйте, я начинающий программист, первокурсник, задали задание по написанию формулы в Пайтон, вот сама формула: вот код...

6
150 / 120 / 36
Регистрация: 01.11.2019
Сообщений: 425
29.10.2024, 13:57
Обязательно надо вставить формулу?
0
 Аватар для kazak
3604 / 2744 / 356
Регистрация: 11.03.2009
Сообщений: 6,306
29.10.2024, 15:22
Добавление формул в excel (openpyxl ) оно?
0
0 / 0 / 0
Регистрация: 29.10.2024
Сообщений: 4
29.10.2024, 15:41  [ТС]
Да, изначально это все делается в ручную. Производится выкачка базы в формате Excel, база чиститься от лишних значений и столбцов, а по итогу в ней необходимо провести манипуляции с функцией ВПР. В целом смог на Python дойти до этапа ВПР, но вот дальше уже никак продвинуться на Linux не могу...В ячейках значится формула, но не сам результат формулы, пробовал перевести результат к единообразному формату str, но по итогу все либо исчезает, либо появляется н/д или всё остается как есть - формула в ячейках....
0
0 / 0 / 0
Регистрация: 29.10.2024
Сообщений: 4
29.10.2024, 15:45  [ТС]
У меня формула прописана, но вот только с pywin32 только получается сохранить результат формулы, с Linux беда-беда, ни в какую..
Миниатюры
Формулы Excel и Python  
0
150 / 120 / 36
Регистрация: 01.11.2019
Сообщений: 425
29.10.2024, 16:55
А нельзя все манипуляции сделать в пандас и уже значения записывать?
0
0 / 0 / 0
Регистрация: 29.10.2024
Сообщений: 4
07.04.2025, 12:46  [ТС]
Спустя определенное количество месяцев я прокачал свои навыки в Pandas и Openpyxl. Всё оказалось довольно просто, и теперь, интегрировав свое приложение в Django, мои коллеги могут без каких-либо затруднений обрабатывать крупные Excel-файлы.

Вот небольшой пример ВПР Excel:

Python
1
2
3
4
5
6
sost_dict = dict(zip(df4["ИНН"], df4["Состояние договора"]))
 
def vlookup_sost(sost):
    return sost_dict.get(sost, "#Н/Д")
 
df1["Состояние договора"] = df1["ИНН"].apply(vlookup_sost)
Надеюсь кому поможет

Тему можете закрыть)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.04.2025, 12:46
Помогаю со студенческими работами здесь

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

Не работают формулы в Excel (xlsx) сгенерированные на python
Недавно начал изучать python. Есть у меня маленький проект, всего 6 небольших плат. Чтобы проще было искать компоненты, слил все в одну...

Формулы в Excel
. Вставить в соответствующие ячейки таблицы формулы для расчета размера стипендии. При этом учесть следующие условия: § размер...

Формулы в Excel
Доброго всем времени суток! кто сможет помочь, буду очень благодарна за помощь... По отдельности все считает, все работает, но...

Формулы в Excel
Доброго времени дня и ночи! Необходимо составить формулу в Excel, где она будет считать следующие данные: Если значение от 0,0000...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Опции темы

Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru