こんにちは、次の 2 つの関数を使用して、その場で PDF を作成してメールで送信しています。私は何を間違っていますか。(ブラウザで表示した場合、PDFエクスポート機能は正常に動作します。)
私が得ているエラーは"TypeError: 'ContentFile' object does not support indexing"です。私が間違っていることは何ですか?このコードのほとんどはいくつかのブログから引用したものなので、正確にどのように機能するかはわかりません。しかし、いくつかのことを理解していない場合は、コメントしてください。返信します。
if request.method=="POST":
form = ReportSendMailForm(request.POST)
if form.is_valid():
email = form.cleaned_data['mail']
message = form.cleaned_data['message']
print email
print message
result = export_pdf(request,id)
file_to_be_sent= ContentFile(result)
#print file_to_be_sent
if result:
#try :
subject, from_email, to = request.user.username+' has sent a report for review',' Dtz Team', email
html_content = render_to_string('email/report.html',{'username':request.user,'messgae':message})
msg = EmailMultiAlternatives(subject,'', from_email, [to])
msg.attach_alternative(html_content, "text/html")
msg.attach("Report.pdf", file_to_be_sent, "application/pdf")
msg.send()
messages.success(request,'Please check your email id '+email+' for further instructions.')
return HttpResponse('success')
#except:
# pass
messages.error(request,'Error occured in the pdf.')
return HttpResponse(status=410)
PDFエクスポート機能
def export_pdf(request,id):
report = Report.objects.get(id=id)
options1 = ReportPropertyOption.objects.filter(report=report,is_active=True)
for option in options1:
option.exterior_images = ReportExteriorImages.objects.filter(report = option)
option.interior_images = ReportInteriorImages.objects.filter(report = option)
option.floorplan_images = ReportFloorPlanImages.objects.filter(report = option)
option.fitouts = ReportFitOut.objects.filter(propertyoption = option)
if (option.gps_longitude):
option.map = "http://maps.google.com/maps/api/staticmap?zoom=12&size=400x400&maptype=roadmap&sensor=false¢er=\""+str(option.gps_latidtude)+","+str(option.gps_longitude)+"\""
html = render_to_string('report/export.html', { 'pagesize' : 'A4', }, context_instance=RequestContext(request,{'options1':options1,'meta':report.meta}))
result = StringIO.StringIO()
pdf = pisa.pisaDocument(StringIO.StringIO(html.encode("UTF-8")), dest=result, link_callback=fetch_resources )
if not pdf.err:
return result
else:
return None