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

Формулы Excel и Python

29.10.2024, 05:58. Показов 2492. Ответов 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
3602 / 2743 / 355
Регистрация: 11.03.2009
Сообщений: 6,304
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
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru