【发布时间】:2016-03-21 02:08:34
【问题描述】:
我尝试使用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>
【问题讨论】:
-
dict = [...]这不是列表吗?那应该是像dict = {...}这样的字典。 -
不,我正在使用从数据库中获取的项目列表,我认为这在这里并不重要。请尽量坚持我的问题的上下文。如果您对我的问题没有任何解决方案,请不要编写任何不必要的 cmets。
标签: html django email django-templates