#tar -xf Python-3.4.3.tgz #cd Python-3.4.3/ #./configure
#yum -y install gcc #yum -y install gdb #yum -y install gcc-c++
#make #make install
#vim /usr/bin/yum #vim /usr/libexec/urlgrabber-ext-down
# coding: utf-8
#from lxml import etree
import logging.handlers
import logging
import os
import sys
import time
import datetime
try:
import xml.etree.cElementTree as ET
except ImportError:
import xml.etree.ElementTree as ET
# 提供日志功能
class logger:
# 先读取XML文件中的配置数据
# 由于config.xml放置在与当前文件相同的目录下,因此通过 __file__ 来获取XML文件的目录,然后再拼接成绝对路径
# 这里利用了lxml库来解析XML
root = ET.parse(os.path.join(os.path.dirname(__file__), 'config.xml')).getroot()
# 读取日志文件保存路径
logpath = root.find('logpath').text
# 读取日志文件容量,转换为字节
logsize = 1024*1024*int(root.find('logsize').text)
# 读取日志文件保存个数
lognum = int(root.find('lognum').text)
# 添加分天日志名
now = datetime.datetime.now()
now_time = now.strftime('%Y%m%d')
log_file_name = sys.argv[0].split('/')[-1].split('.')[0] + '_' + now_time
# 日志文件名:由用例脚本的名称,结合日志保存路径,得到日志文件的绝对路径
logname = os.path.join(logpath, log_file_name)
# 初始化logger
log = logging.getLogger()
# 日志格式,可以根据需要设置
fmt = logging.Formatter('[%(asctime)s][%(filename)s][line:%(lineno)d][%(levelname)s] %(message)s', '%Y-%m-%d %H:%M:%S')
# 日志输出到文件,这里用到了上面获取的日志名称,大小,保存个数
handle1 = logging.handlers.RotatingFileHandler(logname, maxBytes=logsize, backupCount=lognum)
handle1.setFormatter(fmt)
# 同时输出到屏幕,便于实施观察
handle2 = logging.StreamHandler(stream=sys.stdout)
handle2.setFormatter(fmt)
log.addHandler(handle1)
log.addHandler(handle2)
# 设置日志基本,这里设置为INFO,表示只有INFO级别及以上的会打印
log.setLevel(logging.INFO)
# 日志接口,用户只需调用这里的接口即可,这里只定位了INFO, WARNING, ERROR三个级别的日志,可根据需要定义更多接口
@classmethod
def info(cls, msg):
cls.log.info(msg)
return
@classmethod
def warning(cls, msg):
cls.log.warning(msg)
return
@classmethod
def error(cls, msg):
cls.log.error(msg)
return
<?xml version="1.0" encoding="utf-8"?> <config> <!-- 日志保存路径 --> <logpath>/Users/litao/Desktop/mail_html/Log</logpath> <!-- 每个脚本对应的日志文件大小,单位MB --> <logsize>8</logsize> <!-- 每个脚本保存的日志文件个数 --> <lognum>100</lognum> </config>
logger.info('邮件总数量【'+str(len(recivers))+'】')
logger.info('总计发送邮件数量【'+str(send_num)+'】')
logger.info('总计发送错误数量【'+str(error_num)+'】')
logger.info('成功邮箱账号集合:'+','.join(send_success_account))
logger.info('失败邮箱账号集合:'+','.join(send_failure_account))
logger.info('脚本结束------------------------------------------------------------------')
logger.info('')
#coding=utf-8 import smtplib import mimetypes import time import datetime from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart from email.mime.image import MIMEImage #引入外部文件 from Common.log import *
#邮箱内容设置
_content = """
<html>
<style> .title{font-weight:bold;font-size:18px;}</style>
<body>
<p>
<img src="cid:image1">
<br><br>
<span
class="title">【愚人节】将至,您还没准备礼物?那你一定会过个开心的愚人节的</span>
<br>
愚人节就要来啦,礼朵朵给大伙准备了大批量的礼物伴你度过愚人节,具体百度一下【礼朵朵】,赶紧进站选礼物吧~
<br>
选礼物前别忘了先去心愿墙许愿哟,你的愿望可能被礼朵朵看到,可以帮你实现哟,实现的时候别忘了来礼朵朵还愿哈~
<br><br>
<span class="title">【礼朵朵】介绍</span>
<br>
国人从古至今都有送礼的习俗,送礼作为传统之一,一直流传至今,礼尚往来成为人生必修课。
<br>
【礼朵朵】集合商业送礼和现代送礼搭建礼物导购分享平台【朵朵礼物】,带给老少皆宜的送礼分享体验新体验。
<br>
与此同时,礼朵朵还给大伙准备了礼物攻略【礼物说】,让大家可以对礼物有个更全面的了解~
<br><br>
<span class="title">百度搜索【礼朵朵】,开启你的礼物新旅程吧~</span>
<br><br>
</p>
</body>
</html>
"""
#发送邮箱smtp地址 _smtp_address = ['smtp.163.com','smtp.sina.cn','smtp.tom.com','smtp.sohu.com']
def sendMail(sender,reciver,subject,content,passwd,smtpadd):
username=sender
password=passwd
msg=MIMEMultipart('related')
msg['Subject']=subject
#html格式
html=content
htm = MIMEText(html,'html','utf-8')
msg.attach(htm)
#构造图片
fp=open(_root_dir+'Image/logo_small.png','rb')
msgImage=MIMEImage(fp.read())
fp.close()
msgImage.add_header("Content-ID", "<image1>")
msg.attach(msgImage)
fp2=open(_root_dir+'Image/yurenjie.png','rb')
msgImage2=MIMEImage(fp2.read())
fp2.close()
msgImage2.add_header('Content-Disposition', 'attachment',
filename="愚人节活动海报.jpg")
msg.attach(msgImage2)
msg['From']=sender
msg['To']=reciver
#发送邮件
smtp=smtplib.SMTP()
smtp.connect(smtpadd)
smtp.login(username, password)
smtp.sendmail(sender, reciver, msg.as_string())
smtp.quit()
msgImage.add_header("Content-ID", "<image1>")
msg.attach(msgImage)
fp2=open(_root_dir+'Image/yurenjie.png','rb')
msgImage2=MIMEImage(fp2.read())
fp2.close()
msgImage2.add_header('Content-Disposition', 'attachment',
filename="愚人节活动海报.jpg")
#发送邮件 smtp=smtplib.SMTP() smtp.connect(smtpadd) smtp.login(username, password) smtp.sendmail(sender, reciver, msg.as_string()) smtp.quit()
#读取文件中的数据,并将使用,分割的数据变为数组
def readFileToSplit(filepath):
file_stream = open(filepath)
try:
data = file_stream.read()
finally:
file_stream.close()
data_split = data.split(',')
return data_split
if __name__=="__main__":
content=_content
# 接收人的邮箱按照每天2000封来,每天的邮箱都需要更换,文件名最后以日期为准,邮件发送量以日志为准
recivers=readFileToSplit(_root_dir+'Sendmail/mail_test.txt')
# 把4个邮箱的账号都获取到,方便下面for循环中使用
account_163=readFileToSplit(_root_dir+'Account/account163')
account_sina=readFileToSplit(_root_dir+'Account/accountsina')
account_tom = readFileToSplit(_root_dir+'Account/accounttom')
account_sohu = readFileToSplit(_root_dir+'Account/accountsohu')
# 获取邮件发送模板
# 注意模板之间的切换
#log_file_stream = open(_root_dir+'log', 'w+')
logger.info('')
logger.info('脚本开始------------------------------------------------------------------')
# 统计邮件发送量
send_num = 0
# 统计发送出错量
error_num = 0
# 统计发送失败的邮箱发送账号
send_success_account = []
# 统计发送成功的邮箱发送账号
send_failure_account = []
subject_num = len(_subject)
# 最后统计没有发出去的邮箱号,放到下日,继续发送
for i in range(0, len(recivers)):
try:
sendindex = i - error_num
num = i % 30
account = account_163[num].split(':')
addindex=i%4
subjectindex = sendindex%subject_num
if addindex == 1:
account=account_sina[num].split(':')
elif addindex == 2:
account=account_tom[num].split(':')
elif addindex == 3:
account=account_sohu[num].split(':')
sender=account[0]
passwd=account[1]
smtpadd = _smtp_address[addindex]
#smtpstr=str('163')
sendMail(sender, recivers[sendindex], _subject[subjectindex], content, passwd, smtpadd)
#print('发送账号', sender, '正在发送')
str_success_1 = '发送账号【'+sender+'】正在发送'
logger.info(str_success_1)
#writeLog(log_file_stream,str_success_1)
#print('接收序号', i, recivers[i],'发送成功')
str_success_2 = '接受序号【'+str(i)+'】【'+recivers[sendindex]+'】发送成功'
#writeLog(log_file_stream,str_success_2)
logger.info(str_success_2)
logger.info('')
#print('')
send_num+=1
send_success_account.append(sender)
time.sleep(25)
except Exception as e:
#print('停止于:', i, recivers[i],',发送失败')
str_failure_1 = '产生错误于:【'+sender+'】发送失败'
#writeLog(log_file_stream,str_failure_1)
logger.error(str_failure_1)
#print(e)
str_failure_2 = str(e)
#writeLog(log_file_stream,str_failure_2)
logger.error(str_failure_2)
logger.info('')
error_num+=1
send_failure_account.append(sender)
#print('')
#break
#print('安全抵达底部')
#writeLog(log_file_stream,'脚本结束')
set(send_success_account)
set(send_failure_account)
logger.info('邮件总数量【'+str(len(recivers))+'】')
logger.info('总计发送邮件数量【'+str(send_num)+'】')
logger.info('总计发送错误数量【'+str(error_num)+'】')
logger.info('成功邮箱账号集合:'+','.join(send_success_account))
logger.info('失败邮箱账号集合:'+','.join(send_failure_account))
logger.info('脚本结束------------------------------------------------------------------')
logger.info('')
#log_file_stream.close()
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有