通过邮件发送账单详情
admin
2023-07-23 07:02:22
0

1、为了方便财务部分查看个账户支出详情,通过计划任务每天发送账单情况

python 代码如下:

# coding:utf-8

from django.db.models import Q
from jumpserver.api import *
from jumpserver.models import Setting
from django.http import HttpResponse,StreamingHttpResponse
from django.shortcuts import render,render_to_response
from jcloud.aws_iam_scan import *
from jcloud.aws_service_san import *
from jcloud.forms import Aws_monitor_userForm
from jcloud.models import *
import json
import django.utils.timezone as timezone
import time
from datetime import date, timedelta
import boto3
import zipfile
import zlib
import os
import csv
import codecs
import re
import sys
reload(sys)
sys.setdefaultencoding('utf8')

import smtplib
from email.mime.text import MIMEText
from email.header import Header
from django.template import loader
from pprint import pprint
def sendmail():
    def sendaction(html):#定义发送方法
        HOST = "smtp.exmail.qq.com"
        TO = "email"
        FROM = "email"
        msg = MIMEText(html_content,"html","utf-8")
        msg['Subject'] = u'AWS云主机账单'
        msg['From']=FROM
        msg['To']=TO

        try:
            server = smtplib.SMTP()
            server.connect(HOST,"587")
            server.starttls()
            server.login("user","password")
            server.sendmail(FROM, TO, msg.as_string())
            server.quit()
            print "邮件发送成功!"
        except Exception, e:
            print "失败:"+str(e)

    def rescount(accout_tag):#查询账户数量和服务分类
        aws_volumes_list   = Aws_volumes.objects.filter(account_tag=accout_tag)
        aws_snapshots_list = Aws_snapshots.objects.filter(account_tag=accout_tag)
        aws_s3_list        = Aws_s3.objects.filter(account_tag=accout_tag)
        aws_ec2_list       = Aws_ec2.objects.filter(account_tag=accout_tag)
        aws_rds_list       = Aws_rds.objects.filter(account_tag=accout_tag)

        aws_detail         = Aws_detail_price.objects.filter(account_tag=accout_tag)

        ddict = {}
        for d in aws_detail:#遍历所有收费项目,分别累加不同服务价格
            ddict[d.service_id] = d.aws_price

        list_volume = []#卷使用价格
        t_volume = float(0)
        for volume in aws_volumes_list:
            if volume.VolumeId in ddict.keys():
                t_volume = t_volume + float(ddict[volume.VolumeId])
                del(ddict[volume.VolumeId])
        list_volume.append('volume')
        list_volume.append(len(aws_volumes_list))
        list_volume.append(t_volume)
        # print list_volume

        list_snapshots = []#快照价格
        t_snapshots = float(0)
        for key in ddict.keys():
            for snapshots in aws_snapshots_list:
                if re.search(snapshots.SnapshotId,key):
                    t_snapshots = t_snapshots + float(ddict[key])
                    del(ddict[key])

        list_snapshots.append('snapshots')
        list_snapshots.append(len(aws_snapshots_list))
        list_snapshots.append(t_snapshots)
        # print list_snapshots

        list_s3 = []#s3价格
        t_s3 = float(0)
        for s3 in aws_s3_list:
            if s3.Name in ddict.keys():
                t_s3 = t_s3 + float(ddict[s3.Name])
                del(ddict[s3.Name])
        list_s3.append('s3')
        list_s3.append(len(aws_s3_list))
        list_s3.append(t_s3)
        # print list_s3

        list_ec2 = []#ec2价格
        t_ec2 = float(0)
        for ec2 in aws_ec2_list:
            if ec2.InstanceId in ddict.keys():
                t_ec2 = t_ec2 + float(ddict[ec2.InstanceId])
                del(ddict[ec2.InstanceId])
        list_ec2.append('ec2')
        list_ec2.append(len(aws_ec2_list))
        list_ec2.append(t_ec2)
        # print list_ec2

        list_rds = []#rds 价格
        t_rds = float(0)
        for rds in aws_rds_list:
            if rds.DBInstanceArn in ddict.keys():
                t_rds = t_rds + float(ddict[rds.DBInstanceArn])
                del(ddict[rds.DBInstanceArn])
        list_rds.append('rds')
        list_rds.append(len(aws_rds_list))
        list_rds.append(t_rds)
        # print list_rds

        list_other = []#其他价格
        o_price = float(0)
        for o in ddict.keys():
            o_price = o_price + float(ddict[o])
        list_other.append('Others')
        list_other.append(len(ddict))
        list_other.append(o_price)
        # print list_other

        tmp_list = []
        tmp2_list = []
        sprice = float(0)
        for l in [list_ec2,list_volume,list_s3,list_rds,list_snapshots,list_other]:
            sprice = sprice + l[2]
            tmp_list.append(l)
        tmp2_list.append(tmp_list)
        tmp2_list.append(dict_tag[accout_tag])
        tmp2_list.append(sprice)
        if accout_tag == 1:
            tmp2_list.append("RMB")
        else:
            tmp2_list.append("Dollar")

        list_res.append(tmp2_list)
    dict_tag = {}#区分不同账户资源
    dict_tag[1] = '中国:ptmind'
    dict_tag[2] = '海外:administrator'

    list_res = []
    for tag in dict_tag.keys():
        rescount(tag)
    ttime = time.strftime('%m',time.localtime(time.time()))
    html_content = loader.render_to_string('jcloud/sendmail.html',locals())
    # print html_content
    # return my_render('jcloud/sendmail.html', locals(), request)
    # print html_content 
    sendaction(html_content)

发送页面sendmail.html内容如下:



{{ ttime }}月 AWS 账单

#遍历后台渲染内容 {% for t in list_res %}
{% for i in t.0 %} {% endfor %}

{{ t.1 }}


{{ i.0 }} {{ i.1 }} {{ i.2 }}

{{ t.3 }}: {{ t.2 }}

{% endfor %}

最后展示效果如下:
通过邮件发送账单详情

相关内容

热门资讯

欧洲遭遇“更早、更久、更难解”... 澎湃新闻首席记者 刘栋当地时间2026年6月23日,英国伦敦,一名民众坐在公园的阴凉处。视觉中国 图...
江苏省最新平均工资出炉 【大河财立方消息】6月24日,江苏省统计局发布2025年全省城镇单位就业人员年平均工资数据。统计显示...
活力中国调研行|雄安“村”里故... 【大河财立方 记者 陈诗昂 文 王子阳 摄影 雄安新区报道】 到8月底,雄安新区中关村科技园开园就将...
涉及零食、饮料等 37批次食品... 【大河财立方消息】6月23日,市场监管总局办公厅通报37批次食品抽检不合格情况。近期,市场监管总局组...
古巴外长痛批鲁比奥虚伪狡诈 据凤凰卫视报道,6月23日,美国国务院官网发布消息称,鲁比奥宣布将5个古巴实体以及古巴革命领袖劳尔·...
水压低了热水器风压故障 当水压低了热水器风压故障是一种常见问题,这通常是因为在热水器正常运行过程中产生的压力(风压)与水压不...
万家乐燃气灶左右打不着火 这种情况原因有很多种,1、当万家乐灶具启动时,电路中的电压太高时,(灶具利用了过压保护功能),就会切...
万家乐热水器触摸屏开关失灵 万家乐热水器触摸屏开关失灵1、可能是热水器的外部电源出现了接触不良,或者是出现了插头松动的情况,也有...
燃气灶开关阀故障 燃气灶的开关阀是控制燃气灶火焰的一个关键部件,一旦发生故障,将会给使用者带来严重的安全隐患。以下是一...
喷气式燃气灶故障 喷气式燃气灶是现代家庭厨房中广泛使用的一种厨房设备,它能快速加热食物,操作方便,省时省力。但在长期的...