在邮件上发送动态html文件

时间:2015-12-15 10:23:14

标签: html django email django-templates

我尝试使用django-mailgun在邮件上发送html,但它发送整个HTML包含而不仅仅是呈现的HTML表。我想要的是在邮件上发送渲染表。

这是我的代码:

def send_email():
  dict = [....]        #it contains list of data that I want to render 
  html_message = render_to_string('email.html', {'data': dict})
  msg = EmailMessage('Hello', html_message,'mailgun@sandboxccd9ae5xxx6486546476d879gd.mailgun.org', ['abc@gmail.com'])
  msg.content_subtype = "html"  
  msg.send() 

这是我的HTML表格:

  <table style=" border:1px solid black; border-top:1px solid transparent; border-left:1px solid transparent; border-right:1px solid transparent; width:80%;  border-collapse: collapse; font-size:95%; margin-left:10%; margin-right:10%; margin-top:5%; ">
    <thead>
        <tr><th colspan=5  style=" border-bottom:1px solid black; border-right:none; border-left:none; text-align:center; padding:4x"><h4>Activity List</h4></th></tr>
        <tr style="border:1px solid black">
            <th style="border:1px solid black">col 1</th>
            <th style="border:1px solid black">col 2</th>
            <th style="border:1px solid black">col 3</th>
            <th style="border:1px solid black">col 4</th>
            <th style="border:1px solid black">col 5</th>
        </tr>
    </thead>
    <body>
        {% for item in data %}
        <tr>
            <td style="border:1px solid; text-align:right; padding: 4px">{{ item.data1 }}</td>
            <td style="border:1px solid; text-align:right; padding: 4px">{{ item.data2 }}</td>
            <td style="border:1px solid; text-align:right; padding: 4px">{{ item.data3 }}</td>
            <td style="border:1px solid; text-align:right; padding: 4px">{{ item.data4 }}</td>
            <td style="border:1px solid; text-align:right; padding: 4px">{{ item.data5 }}</td>
        </tr>
        {% endfor %}
    </body>

我收到了我的邮件:

<table style=" border:1px solid black; border-top:1px solid transparent; border-left:1px solid transparent; border-right:1px solid transparent; width:80%;  border-collapse: collapse; font-size:95%; margin-left:10%; margin-right:10%; margin-top:5%; ">
    <thead>
        <tr><th colspan=5  style=" border-bottom:1px solid black; border-right:none; border-left:none; text-align:center; padding:4x"><h4>Activity List</h4></th></tr>
        <tr style="border:1px solid black">
            <th style="border:1px solid black">col 1</th>
            <th style="border:1px solid black">col 2</th>
            <th style="border:1px solid black">col 3</th>
            <th style="border:1px solid black">col 4</th>
            <th style="border:1px solid black">col 5</th>
        </tr>
    </thead>
    <tbody>

        <tr>
            <td style="border:1px solid; text-align:right; padding: 4px">data 11</td>
            <td style="border:1px solid; text-align:right; padding: 4px">data 12</td>
            <td style="border:1px solid; text-align:right; padding: 4px">data 13</td>
            <td style="border:1px solid; text-align:right; padding: 4px">data 14</td>
            <td style="border:1px solid; text-align:right; padding: 4px">data 15</td>
        </tr>

        <tr>
            <td style="border:1px solid; text-align:right; padding: 4px">data 21</td>
            <td style="border:1px solid; text-align:right; padding: 4px">data 22</td>
            <td style="border:1px solid; text-align:right; padding: 4px">data 23</td>
            <td style="border:1px solid; text-align:right; padding: 4px">data 24</td>
            <td style="border:1px solid; text-align:right; padding: 4px">data 25</td>
        </tr>

        </tbody>

</table>

1 个答案:

答案 0 :(得分:3)

使用Django的电子邮件库,您可以使用EmailMultiAlternatives类来完成此操作。

xRecord.isFieldDataRetrieved

它对我有用。试试这个。 参考: https://docs.djangoproject.com/en/1.8/topics/email/#sending-alternative-content-types

相关问题