# -*- coding: utf-8 -*-
from __future__ import unicode_literals
import os
import time
import hashlib
from django.conf import settings
from django.core.mail import EmailMessage
from django.core.paginator import Paginator, PageNotAnInteger, EmptyPage
def file_md5(fname):
hash_md5 = hashlib.md5()
with open(fname, "rb") as f:
for chunk in iter(lambda: f.read(4096), b""):
hash_md5.update(chunk)
return hash_md5.hexdigest()
def send_html_mail(subject, html_content, recipient_list):
"""
发邮件
"""
msg = EmailMessage(subject, html_content, settings.EMAIL_HOST_USER, recipient_list)
msg.content_subtype = 'html' # main content is now text/html
msg.send(fail_silently=False)
def backup_database(host, port, user, pwd, db):
"""
备份数据库
"""
bak = 'bak-{0}-{1}.sql'.format(db, time.strftime('%Y-%m-%d-%H-%M-%S'))
bak = os.path.join('/tmp/', bak)
cmd = 'mysqldump -h{host} --port={port} -u{user} --password={pwd} {db} > {bak};'.format(
host=host, port=port, user=user, pwd=pwd, db=db, bak=bak
)
ret = os.system(cmd)
if ret:
raise RuntimeError('mysqldump error')
else:
return os.path.abspath(bak)
def execute_sql(host, port, user, pwd, db, sql):
"""
还原数据库
"""
cmd = 'mysql --default-character-set=utf8 -h{host} --port={port} -u{user} --password={pwd} {db} < {sql};'.format(
host=host, port=port, user=user, pwd=pwd, db=db, sql=sql
)
return os.system(cmd)
def serialize_form_errors(form):
errors = []
for field in form:
if field.errors:
errors.append(field.label + ':' + ','.join([err for err in field.errors]))
return '\n'.join(errors)
def paginate(data, current_page=1, page_num=20):
"""
分页函数
"""
paginator = Paginator(data, page_num)
try:
show_lines = paginator.page(current_page)
except PageNotAnInteger:
# If page is not an integer, deliver first page.
show_lines = paginator.page(1)
except EmptyPage:
# If page is out of range (e.g. 9999), deliver last page of results.
show_lines = paginator.page(paginator.num_pages)
return show_lines
python script (发邮件、备份还原数据库、分页函数)
最新推荐文章于 2024-07-27 20:57:33 发布