Categories: 'IT 제품리뷰'

[파이썬] 보고서 생성 및 전송 자동화

파이썬을 통해 보고서를 생성하고 자동으로 전송하는 프로그램을 만들어 보도록 합니다.

 

[파이썬] 보고서 생성 및 전송 자동화

 

[파이썬] 보고서 생성 및 전송 자동화


 

소개

보고서 작성 및 전송은 많은 기업과 조직에서 필요한 일입니다. 이러한 작업들을 자동화하여 생산성과 효율성을 향상시킬 수 있습니다. Python은 이러한 작업에 이상적인 프로그래밍 언어입니다. 이 글에서는 Python을 사용하여 보고서를 생성하고 전송하는 방법에 대해 알아보겠습니다.

보고서 생성

Python을 사용하면 다양한 방법으로 보고서를 생성할 수 있습니다. 가장 일반적인 방법은 openpyxl, pandas, matplotlib 등의 라이브러리를 사용하여 Excel, CSV, PDF, 그래프와 같은 형식으로 보고서를 생성하는 것입니다.

Excel 보고서 생성

openpyxl 라이브러리를 사용하면 Excel 파일을 생성하고 편집할 수 있습니다. 예를 들어, 아래와 같은 코드로 보고서 템플릿을 만들고 데이터를 채울 수 있습니다.

import openpyxl

# 보고서 템플릿 열기
wb = openpyxl.load_workbook('report_template.xlsx')
ws = wb['Sheet1']

# 데이터 채우기
ws['A1'] = '이름'
ws['B1'] = '나이'

ws['A2'] = 'John'
ws['B2'] = 25

# 보고서 저장
wb.save('report.xlsx')

CSV 보고서 생성

csv 모듈을 이용하면 간단하게 CSV 보고서를 생성할 수 있습니다. 아래는 예시 코드입니다.

import csv

data = [
    ['이름', '나이'],
    ['John', 25],
    ['Amy', 32],
    ['Mike', 45]
]

with open('report.csv', 'w', newline='') as file:
    writer = csv.writer(file)
    writer.writerows(data)

PDF 보고서 생성

reportlab 라이브러리를 사용하면 Python으로 PDF 보고서를 생성할 수 있습니다. 아래는 예시 코드입니다.

from reportlab.pdfgen import canvas

# PDF 생성
c = canvas.Canvas('report.pdf')

# 텍스트 추가
c.drawString(100, 750, '보고서 생성 및 전송 자동화')
c.drawString(100, 700, '보고서 생성 예시입니다.')

# PDF 저장
c.save()

보고서 전송

보고서를 생성했다면 이제 해당 보고서를 원하는 대상에게 전송해야 합니다. Python에서는 smtplib 라이브러리를 사용하여 이메일을 보낼 수 있습니다. 예를 들어, Gmail을 사용하여 이메일을 전송하는 코드는 다음과 같습니다.

import smtplib
from email.mime.text import MIMEText

# 이메일 설정
smtp_server = 'smtp.gmail.com'
smtp_port = 587
sender_email = 'your_email@gmail.com'
sender_password = 'your_password'
recipient_email = 'recipient_email@gmail.com'

# 이메일 내용 작성
message = MIMEText('보고서를 보내드립니다.')
message['Subject'] = '보고서 전송'
message['From'] = sender_email
message['To'] = recipient_email

# 이메일 전송
with smtplib.SMTP(smtp_server, smtp_port) as smtp:
    smtp.starttls()
    smtp.login(sender_email, sender_password)
    smtp.send_message(message)

자동화

매번 코드를 실행하여 보고서를 생성하고 전송하는 것은 번거로울 수 있습니다. 이를 자동화하기 위해 Python의 schedule 라이브러리와 함께 사용할 수 있습니다. 해당 라이브러리를 사용하여 일정 시간에 보고서 생성 및 전송 작업을 실행할 수 있습니다.

예를 들어, 매일 오전 9시에 보고서를 생성하고 전송하는 코드는 다음과 같습니다.

import schedule
import time

def generate_report():
    # 보고서 생성 및 전송 코드 작성

# 매일 9시에 generate_report 함수 실행
schedule.every().day.at("09:00").do(generate_report)

while True:
    schedule.run_pending()
    time.sleep(1)

결론

Python을 사용하면 보고서 생성 및 전송 작업을 쉽게 자동화할 수 있습니다. Excel, CSV, PDF 형식의 보고서를 생성하고 smtplib를 이용하여 이메일로 전송할 수 있다는 것을 알아보았습니다. 또한, schedule 라이브러리를 통해 작업을 자동으로 실행할 수 있다는 것도 알게 되었습니다. 이러한 방법을 사용하여 보다 효율적으로 보고서 작성과 전송을 처리할 수 있습니다.

urjent

Share
Published by
urjent

Recent Posts

스페이스X 나스닥100 편입 7월 7일 확정…상장 한 달 만에 초고속 합류

스페이스X가 오는 7월 7일부터 나스닥100 지수에 공식 편입됩니다. 나스닥 거래소는 26일 공식 공시를 통해 결정을…

5시간 ago

김포 인천 마약 좀비 영상 확산… 경찰 “정확하지 않은 내용, 명예훼손 우려”

2026년 6월 27일 기준 SNS를 중심으로 인천과 김포에서 촬영된 ‘마약 의심’ 영상들이 잇따라 공유되고 있으며,…

6시간 ago

이집트 이란 월드컵 예상 2026년 6월 27일 G조 최종전, 한국의 32강 진출 희망은?

2026 북중미 월드컵 조별리그 최종전이 6월 27일(한국시간) 하루 만에 대결을 앞두고 있습니다. 한국은 1승2패로 승점…

10시간 ago

장기하 윤가이 열애설 공식 인정… 18살 차 극복한 2년 교제

장기하와 윤가이가 2년 이상 교제 중인 사실을 소속사가 2026년 6월 27일 공식으로 인정했습니다. 쿠팡플레이 예능…

13시간 ago

제이오션 중공업 주가 전망: 군산조선소 인수 확정과 조선업 호황 기대감

제이오션 중공업이 전북 군산 조선소 인수를 위한 양수도 본계약을 체결한 것으로 확인됩니다. 이는 침체된 지역…

18시간 ago

튀르키예 활성단층 증가, 13년 만에 44% 늘어…이스탄불 강진 우려

튀르키예의 활성단층 수가 13년 만에 44% 증가한 것으로 공식 확인됐습니다. 2026년 6월 22일 튀르키예 에너지천연자원부…

24시간 ago