我尝试使用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>
答案 0 :(得分:3)
使用Django的电子邮件库,您可以使用EmailMultiAlternatives类来完成此操作。
xRecord.isFieldDataRetrieved
它对我有用。试试这个。 参考: https://docs.djangoproject.com/en/1.8/topics/email/#sending-alternative-content-types