python实现读取excel文件到邮件正文发送邮件功能

python自学笔记(一)
我自己的学习完全是在需求和实践中摸索的,没有系统的学习,所以代码写得不是特别好,希望可以和大家互相交流学习。
代码实现功能说明:
读取固定的一个excel文件的内容,以html的形式将excel文件的内容展示在邮件正文中,显示为表格的形式,同时在邮件正文中拼接其他的文件内容,另将读取的excel文件作为邮件附件发送。

import smtplib
from email.mime.multipart import  MIMEMultipart
from email.header import Header
from email.mime.text import MIMEText
from email.mime.application import MIMEApplication
import xlrd
import datetime



#创建连接和登陆,smtp服务器地址,端口,发件人账号和密码,
con = smtplib.SMTP_SSL('smtp.163.com',465)
con.login('****@163.com','***password***')


#准备基础数据,主题、发件人、收件人
msg = MIMEMultipart()
#邮件主题
msg['Subject'] = Header('邮件主题测试','utf-8').encode()
#发件人
msg['From'] = '*****@163.com <****@163.com>'
#收件人
msg['To'] = '[email protected]'



#写邮件,读取excel文件内容作为邮件正文
def mailWrite():
    #表格的标题和头
    header = ''
    th = ''#打开文件#filepath设置详细的文件地址
    filepath ='E:\报盘配置报表-20200512.xlsx'
    book = xlrd.open_workbook(filepath)
    sheet = book.sheet_by_index(0)#获取行列的数目,并以此为范围遍历获取单元数据#nrows 行数,ncols 列数
    nrows = sheet.nrows -1
    ncols = sheet.ncols
    body =''
    cellData =1for i inrange(1,nrows+1):
        td =''for j inrange(ncols):
            cellData = sheet.cell_value(i , j)#读取单元格数据,赋给cellData变量供写入HTML表格中
            tip =''
            td = td + tip
            tr =''+ td +''#tr = tr.encode('utf-8')
        body = body + tr
        tail ='
本地地址PBU
' + cellData + '
'
mailcontent = header+th+body+tail #将excel文件的内容转换为html格式,后续在邮件中拼接 return mailcontent #邮件正文内容 content = mailWrite() cs = """

今日报盘配置信息如下:

"""
contents = cs + content html = MIMEText(contents,'html','utf-8') msg.attach(html) #邮件附件 part = MIMEApplication(open('E:\报盘配置报表-20200512.xlsx', 'rb').read()) #filename=邮件附件中显示的文件的名称,可自定义 part.add_header('Content-Disposition', 'attachment', filename="报盘配置报表-20200512.xlsx") msg.attach(part) #发送邮件 #sendmail(发件人,收件人,内容) con.sendmail('*****@163.com','[email protected]',msg.as_string()) con.quit() print('发送成功!')

你可能感兴趣的:(python自学笔记)