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

Запись данных на существующий лист Excel из дата-фрейма pandas

04.06.2024, 16:55. Показов 1727. Ответов 3

Студворк — интернет-сервис помощи студентам
Доброго времени суток!

Помогите, пожалуйста, с одной проблемой. Никак не могу понять, почему не работает код.

Суть задачи - пройтись по ряду вложенных папок и переложить часть данных из одних файлов в другие по определённым признакам. Вот код. Я беру данные из файла file_1 и записываю в датафрейм. Затем из этого датафрейма хочу записать данные после фильтрации в уже существующий файл DL_path, на существующий лист "гр04_РI_ввод". В общем, код завершается без ошибок, все переменные записываются как надо, дата-фреймы создаются тоже без проблем. Но вот вот в итоге на лист "гр04_РI_ввод" ничего не записывается, он остается пустым. В чем моя ошибка?

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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
from pathlib import Path
from openpyxl import load_workbook
import pandas as pd
 
folder_path_str = input("Введите путь к папке: ")
folder_path = Path(folder_path_str)
 
ident_1 = None
excel_file = None
DL_path = None
 
#идем циклом по папкам с макрорегионами
for mr in folder_path.iterdir():
    if mr.is_dir():
        #идем циклом по папкам с филиалами внутри макрорегионов
        for fil in mr.iterdir():
            if fil.is_dir():
 
                for excel_file in fil.iterdir():
                    
                    if excel_file.name.startswith("__DataLoаder") and excel_file.suffix == ".xlsx":
                        
                        wb = load_workbook(filename=excel_file)
                        
                        DL_path = excel_file.resolve()
                        
                        sheet_1 = wb["гр04_РI_ввод"]
                        ident_1 = sheet_1["A1"].value
                                
                        print(ident_1)
                          
                for file_1 in fil.iterdir():
                        
                    if file_1.name.startswith(ident_1) and file_1.suffix == ".xlsx":
                        
                        df = pd.read_excel(file_1, sheet_name='СВОД', skiprows=2)  # Создаем DataFrame из файла Excel
                        
                        # Удаляем строки, содержащие пустые значения в столбце "группа по ОКОФ"
                        df_filtered = df.dropna(subset=['55'])
                        
                        # Удаляем строки, содержащие "-" в столбце "группа по ОКОФ"
                        df_filtered = df_filtered[df_filtered['55'] != "-"]
                        
                        # Удаляем строки, содержащие (пусто) в столбце "группа по ОКОФ"
                        df_filtered = df_filtered[df_filtered['55'] != "(пусто)"]
                        
                        print(df_filtered)
                        print(excel_file)
                        print(DL_path)
                        
                        try:
             
 
                            df_filtered.to_excel(DL_path, sheet_name="гр04_РI_ввод", startrow=8, index=False, engine='openpyxl')
        
                        except Exception as e:
                
                            print(f"Ошибка при сохранении данных в Excel: {str(e)}")
                            
                        wb.save(DL_path)
Судя по всему, проблема вот в этой строке:

Python
1
df_filtered.to_excel(DL_path, sheet_name="гр04_РI_ввод", startrow=8, index=False, engine='openpyxl')
Я как-то неправильно обращаюсь к книге, в которую записываю содержимое дата-фрейма?

Вот так тоже пробовал, без результата:

Python
1
df_filtered.to_excel(DL_path, sheet_name="гр04_РI_ввод", startrow=8, index=False)
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.06.2024, 16:55
Ответы с готовыми решениями:

Очему при загрузке дата фрейма из excel в pandas дата меняет формат
Ребята скажите пжл почему при загрузке дата фрейма из excel в pandas дата с такого формата 2023-09-18 переходит в такой 2023-09-18...

Создать строку из данных фрейма Pandas
Добрый день! Подскажите как из первой и третьей колонки фрейма создать строку вида: A (1); D (2); D (2); ... import pandas as pd ...

Запись данных на текущий лист Excel
Доброго времени суток! Подскажите, пожалуйста, каким образом можно записать данные на открытый(активный) лист. Использовать...

3
0 / 0 / 0
Регистрация: 20.03.2024
Сообщений: 16
05.06.2024, 17:06  [ТС]
Вот такой ещё вариант. Но результат тот же. Не заносятся данные из дата-фрейма.

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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
from pathlib import Path
import openpyxl
from openpyxl import load_workbook
import pandas as pd
 
 
folder_path_str = input("Введите путь к папке: ")
folder_path = Path(folder_path_str)
 
#справочник в виже словаря
#{"лист в файле DataLoad": ["с чего начинается файл, откуда будем брать данные", "с какого листа бьерем", "столбец, по которому фильтруем"]
 
spr = {
    "гр04_РI_ввод": ["Шаблон_Раз_I_гр_4_отчет_о_вводе", "СВОД", "16"],
    "гр04_РI_модерн": ["Шаблон_Раз_I_гр_4_отчет_о_изм.", "СВОД", "2"],
    "гр05_РI": ["Шаблон_Раз_I_гр_5_отчет_о_принятых", "Свод", "17"],
    "графа кор_РI": ["Шаблон_Раз_I_гр_5_отчет_о_произв", "свод", "31"],
    "гр06-08;13_РI": ["Шаблон_Раз_I_гр_6-8,гр13", "Свод лля графы 6,7,8 и 13", "4"],
    "гр09,10,11,12_РI+РII+РIII": ["Шаблон_Раз_I_гр_9-12", "СВОД_нов", "25.6"],
}
 
#идем циклом по папкам с макрорегионами
for mr in folder_path.iterdir():
    if mr.is_dir():
        
        #идем циклом по папкам с филиалами внутри макрорегионов
        for fil in mr.iterdir():
 
            for shab in fil.iterdir():
                        
                if shab.name.startswith(spr["гр04_РI_ввод"][0]) and shab.suffix == ".xlsx":
                        
                    df = pd.read_excel(shab, sheet_name=spr["гр04_РI_ввод"][1], skiprows=2)  # Создаем DataFrame из файла Excel
                        
                    # Удаляем строки, содержащие пустые значения в столбце "группа по ОКОФ"
                    df_filtered = df.dropna(subset=[spr["гр04_РI_ввод"][2]])
                        
                    # Удаляем строки, содержащие "-" в столбце "группа по ОКОФ"
                    df_filtered = df_filtered[df_filtered[spr["гр04_РI_ввод"][2]] != "-"]
                        
                    # Удаляем строки, содержащие (пусто) в столбце "группа по ОКОФ"
                    df_filtered = df_filtered[df_filtered[spr["гр04_РI_ввод"][2]] != "(пусто)"]
                    
                    print(df_filtered)
                    
                    #определяем путь к файлу, куда будем вносить данные из шаблонов
                    DL_file = next((f for f in fil.iterdir() if f.name.startswith("__DataLoаder")), None)
                    
                    print(DL_file)
                       
                    #определяем в книгу рабочий файл
                    DL_wb = load_workbook(DL_file)
                    
                    try:
                        
                        # записываем данные из датафрейма df_filtered на лист "гр04_РI_ввод" в книге Excel DL_file
                        df_filtered.to_excel(DL_file, sheet_name="гр04_РI_ввод", index=False, header=False, startrow=8)
                        
                        #сохраняем рабочий файл
                        DL_wb.save(DL_file)
                        
                    except Exception as e:
                        
                        print("Ошибка при записи данных в файл:", e)
0
1709 / 578 / 74
Регистрация: 10.04.2009
Сообщений: 9,293
06.06.2024, 14:02
sir_pit, так а зачем сразу три желания задействовать - папка, дата-фрейм, эксель, начните с конца - просто эксель без папки, дата-фрейма и потом добавляйте, так и код будет меньше и разбираться проще...
0
0 / 0 / 0
Регистрация: 20.03.2024
Сообщений: 16
06.06.2024, 16:06  [ТС]
sir_pit, так а зачем сразу три желания задействовать - папка, дата-фрейм, эксель, начните с конца - просто эксель без папки, дата-фрейма и потом добавляйте, так и код будет меньше и разбираться проще...
Так всё остальное работает нормально. Проблема в итоговом шаге - записи содержимого дата-фрейма в айл. Даже удалось добиться, чтобы данные записывались. Только вот при этом удаляются все остальные листы.

Из последних попыток вот этот код

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
DL_file = next((f for f in fil.iterdir() if f.name.startswith("__DataLoаder")), None)
                
                    try:
                        
                        wb = load_workbook(DL_file)
                        
                        with pd.ExcelWriter(DL_file, engine='openpyxl', mode='a') as writer:
                            df_filtered.to_excel(writer, sheet_name="гр04_РI_ввод", startrow=8, startcol=0, header=None, index=False)
                        
                        wb.save(DL_file) 
       
                    except Exception as e:
                        
                        print("Ошибка при записи данных в файл:", e)
Вызывает ошибку
Python
1
Sheet 'гр04_РI_ввод' already exists and if_sheet_exists is set to 'error'
Ну да, лист существует. Я туда хочу вставить данные. Почему не работает?

Добавлено через 23 минуты
А если вот так сделать

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
DL_file = next((f for f in fil.iterdir() if f.name.startswith("__DataLoаder")), None)
                
                    try:
                        
                        wb = load_workbook(DL_file)
                        
                        with pd.ExcelWriter(DL_file, engine='openpyxl', mode='a', if_sheet_exists='overlay') as writer:
                            df_filtered.to_excel(writer, sheet_name="гр04_РI_ввод", startrow=8, startcol=0, header=None, index=False)
                        
                        wb.save(DL_file) 
       
                    except Exception as e:
                        
                        print("Ошибка при записи данных в файл:", e)
То ошибки не выводится. Но данные на лист не заносятся.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.06.2024, 16:06
Помогаю со студенческими работами здесь

Как в pandas добавить запись в excel файл не перезаписывая его?
Я использую pandas для записи в файл Excel. Если использовать mode='a' то выскакивает ошибка. Помогите плз, кто знает. import requests ...

Экспорт данных из DataGridView в существующий Excel
Доброго времени суток. Прошу вас помочь с одной проблемой. У меня есть код который по нажатию кнопки создает аналогичную таблицу в exel...

Экспорт данных из excel в существующий xml
Добрый день.. Может у кого-то есть готовый скриптик для экспорта данных из excel в хml... Файлы для примера прилагаются есть много Хмл...

Добавление данных из Datagridview в существующий Excel файл
Привет! Код работает, но он в в файле перезаписывает данные, а мне надо чтобы данные в excel пополнялись а не перезаписывал данные...

Запись лист объектов в Excel
Здравствуйте. Подскажите как можно записать List в excel используя библиотеку Interop. Я вывожу данные на консоль вот так: class...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru