Использование pandas для автоматического создания операторов из шаблона [закрыто]Python

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Использование pandas для автоматического создания операторов из шаблона [закрыто]

Сообщение Anonymous »

Текущий код создаёт лишь один файл на выходе и меняет только [свидетельство]
Не могу определить в чём проблема
Все столбцы в excel файле я назвал, все ключи соответствую коду

Код: Выделить всё

import pandas as pd
from docx import Document
import os

excel_file = 'Book1.xlsx'
column_names = [
'ФИО_должника', 'адрес', 'дата_рождения', 'паспорт', 'задолженность',
'пошлина', 'период_задолженности', 'населённый_пункт', 'улица',
'дом', 'квартира', 'кадастровый_номер', 'свидетельство'
]
df = pd.read_excel(excel_file, names=column_names, header=None)

print(df.columns)

template_path = 'Заявление.docx'

output_folder = 'output_docs'
os.makedirs(output_folder, exist_ok=True)

def create_document(row):

doc = Document(template_path)
output_path = os.path.join(output_folder, f"Заявление_{row['ФИО_должника']}.docx")

for paragraph in doc.paragraphs:
if '[ФИО_должника]' in paragraph.text:
paragraph.text = paragraph.text.replace('[ФИО_должника]', str(row['ФИО_должника']))
if '[место_жительства]' in paragraph.text:
paragraph.text = paragraph.text.replace('[место_жительства]', str(row['место_жительства']))
if '[дата_и_место_рождения]' in paragraph.text:
paragraph.text = paragraph.text.replace('[дата_и_место рождения]', str(row['дата_и_место_рождения']))
if '[данные_паспорта]' in paragraph.text:
paragraph.text = paragraph.text.replace('[данные_паспорта]', str(row['паспорт']))
if '[размер_задолженности]' in paragraph.text:
paragraph.text = paragraph.text.replace('[размер_задолженности]', str(row['задолженность']))
if '[пошлина]' in paragraph.text:
paragraph.text = paragraph.text.replace('[пошлина]', str(row['пошлина']))
if '[период_задолженности]' in paragraph.text:
paragraph.text = paragraph.text.replace('[период_задолженности]', str(row['период_задолженности']))
if '[населённый_пункт]' in paragraph.text:
paragraph.text = paragraph.text.replace('[населённый_пункт]', str(row['населённый_пункт']))
if '[улица]' in paragraph.text:
paragraph.text = paragraph.text.replace('[улица]', str(row['улица']))
if '[дом]' in paragraph.text:
paragraph.text = paragraph.text.replace('[дом]', str(row['дом']))
if '[квартира]' in paragraph.text:
paragraph.text = paragraph.text.replace('[квартира]', str(row['квартира']))
if '[кадастровый_номер]' in paragraph.text:
paragraph.text = paragraph.text.replace('[кадастровый_номер]', str(row['кадастровый_номер']))
if '[свидетельство]' in paragraph.text:
paragraph.text = paragraph.text.replace('[свидетельство]', str(row['свидетельство']))

doc.save(output_path)

for index, row in df.iterrows():
try:
create_document(row)
print(f"Документ для {row['ФИО_должника']} успешно создан.")
except Exception as e:
print(f"Ошибка при создании документа для {row['ФИО_должника']}: {e}")

print("Документы успешно созданы и сохранены в папку 'output_docs'.")
Формат данных в excel:
название столбцов [ФИО_должника] [адрес] [размер задолженности]
далее данные
Так выглядит шаблон заявления
Переименовывать столбцы в excel, менять внешний цикл где вызов функции

Подробнее здесь: https://stackoverflow.com/questions/788 ... a-template
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Python»