Django生成PDF文檔顯示在網(wǎng)頁上以及解決PDF中文顯示亂碼的問題
項目地址:https://github.com/PythonerKK/django-generate-pdf/tree/master
這個demo實現(xiàn)了通過用戶輸入自己的個人信息生成一份簡歷pdf,來闡述如何使用Django的HttpResponse生成PDF的文檔。
先上效果圖:
安裝依賴庫
首先安裝Django最新版2.2.2和PDF依賴包xhtml2pdf
pip install django pip install xhtml2pdf
編寫表單驗證
為了簡單起見,這個demo依賴數(shù)據(jù)庫,只需要表單驗證數(shù)據(jù)即可
pdf/forms.py
class MessageForm(forms.Form): ''' 表單驗證 ''' name = forms.CharField(required=True) degree = forms.CharField(required=True) edu = forms.CharField(required=True) work = forms.CharField(required=True) tech = forms.CharField(required=True) phone = forms.CharField(required=True)
編寫類視圖
pdf/views.py
由于這里我們只需要表單視圖,所以只創(chuàng)建了一個類視圖,post用來驗證表單數(shù)據(jù)是否都存在,如果存在就把表單數(shù)據(jù)渲染到PDF模板中,經(jīng)過處理后返回PDF的響應(yīng)response。
這里可以使用Django的通用類視圖FormView構(gòu)建,代碼更簡潔
class MessageView(View): def get(self, request): form = MessageForm(data=request.GET) return render(request, 'index.html', { 'form': form }) def post(self, request): form = MessageForm(data=request.POST) if form.is_valid(): response = generate_pdf_response(context=form.cleaned_data) return response return redirect(reverse('pdf:message'))
編寫生成PDF響應(yīng)response
view.py
這里為了方便直接把處理函數(shù)寫到視圖函數(shù)的文件里
def link_callback(uri): if uri.startswith(settings.MEDIA_URL): path = os.path.join(settings.MEDIA_ROOT, uri.replace(settings.MEDIA_URL, "")) elif uri.startswith(settings.STATIC_URL): path = os.path.join(settings.STATIC_ROOT, uri.replace(settings.STATIC_URL, "")) else: return uri # 確保本地文件存在 if not os.path.isfile(path): raise Exception( "Media URI 必須以以下格式開頭" f"'{settings.MEDIA_URL}' or '{settings.STATIC_URL}'") return path def generate_pdf_response(context): response = HttpResponse(content_type="application/pdf") response["Content-Disposition"] = \ f"attachment; filename='{context['name']}.pdf'" html = render_to_string("pdf.html", context=context) status = pisa.CreatePDF(html, dest=response, link_callback=link_callback) if status.err: return HttpResponse("PDF文件生成失敗") return response
解決中文亂碼問題
需要下載中文字體msyh.ttf放在static目錄下的font目錄,用來設(shè)置全局字體。這些文件都在github倉庫里。
def font_patch(): from reportlab.pdfbase.ttfonts import TTFont from reportlab.pdfbase import pdfmetrics from xhtml2pdf.default import DEFAULT_FONT pdfmetrics.registerFont(TTFont('yh', '{}/font/msyh.ttf'.format( settings.STATICFILES_DIRS[0]))) DEFAULT_FONT['helvetica'] = 'yh'
把這個函數(shù)放在生成PDF響應(yīng)前
按照以上大致步驟大家就能夠生成PDF文件了,可以在網(wǎng)頁中瀏覽、放大、縮小,也可以下載,非常方便、簡單。
大家可以直接clone一份代碼試試效果
項目地址:https://github.com/PythonerKK/django-generate-pdf/tree/master
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python中用logging實現(xiàn)日志滾動和過期日志刪除功能
這篇文章主要介紹了python中用logging實現(xiàn)日志滾動和過期日志刪除功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-08-08python3 與python2 異常處理的區(qū)別與聯(lián)系
這篇文章主要介紹了python3 與python2 異常處理的區(qū)別與聯(lián)系的相關(guān)資料,需要的朋友可以參考下2016-06-06python Tcp協(xié)議發(fā)送和接收信息的例子
今天小編就為大家分享一篇python Tcp協(xié)議發(fā)送和接收信息的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-07-07Pandas DataFrame中實現(xiàn)取單個值的讀取和修改
這篇文章主要介紹了Pandas DataFrame中實現(xiàn)取單個值的讀取和修改,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10CoAtNet實戰(zhàn)之對植物幼苗圖像進行分類(pytorch)
谷歌的最新模型CoAtNet做了卷積 + Transformer的融合,在ImageNet-1K數(shù)據(jù)集上取得88.56%的成績。本文主要介紹如何用CoAtNet實現(xiàn)植物幼苗圖像的分類。感興趣的小伙伴可以學習一下2021-12-12