如何使用Django Admin管理后臺(tái)導(dǎo)入CSV
假設(shè)你需要允許在Hero管理頁面上導(dǎo)入CSV數(shù)據(jù)。為此,您需要添加一個(gè)指向更改Hero列表頁面的鏈接,點(diǎn)擊這個(gè)鏈接會(huì)跳轉(zhuǎn)到上傳頁面。你需要編寫一個(gè)處理POST請(qǐng)求的方法,來從CSV文件中獲取數(shù)據(jù)對(duì)象:
class CsvImportForm(forms.Form): csv_file = forms.FileField()@admin.register(Hero)class HeroAdmin(admin.ModelAdmin, ExportCsvMixin): ... change_list_template = 'entities/heroes_changelist.html' def get_urls(self): urls = super().get_urls() my_urls = [ ... path(’import-csv/’, self.import_csv), ] return my_urls + urls def import_csv(self, request): if request.method == 'POST': csv_file = request.FILES['csv_file'] reader = csv.reader(csv_file) # Create Hero objects from passed in data # ... self.message_user(request, 'Your csv file has been imported') return redirect('..') form = CsvImportForm() payload = {'form': form} return render( request, 'admin/csv_form.html', payload )
然后創(chuàng)建模板文件entities/heroes_changelist.html,以覆蓋原有的admin/change_list.html:
{% extends ’admin/change_list.html’ %}{% block object-tools %} <a href='http://m.4tl426be.cn/bcjs/import-csv/' rel='external nofollow' >Import CSV</a> <br /> {{ block.super }}{% endblock %}
最后,創(chuàng)建上傳頁面csv_form.html:
{% extends ’admin/base.html’ %}{% block content %} <div> <form action='.' method='POST' enctype='multipart/form-data'> {{ form.as_p }} {% csrf_token %}<button type='submit'>Upload CSV</button> </form> </div> <br />{% endblock %}
修改完后,會(huì)在更改Hero后臺(tái)列表頁面上會(huì)有一個(gè)Import CSV的鏈接.
點(diǎn)擊后上傳頁面顯示如下。
以上就是如何使用Django Admin管理后臺(tái)導(dǎo)入CSV的詳細(xì)內(nèi)容,更多關(guān)于Django Admin導(dǎo)入CSV的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. PHP循環(huán)與分支知識(shí)點(diǎn)梳理2. 解析原生JS getComputedStyle3. ASP中實(shí)現(xiàn)字符部位類似.NET里String對(duì)象的PadLeft和PadRight函數(shù)4. XML入門精解之結(jié)構(gòu)與語法5. 使用純HTML的通用數(shù)據(jù)管理和服務(wù)6. javascript xml xsl取值及數(shù)據(jù)修改第1/2頁7. UDDI FAQs8. 利用CSS3新特性創(chuàng)建透明邊框三角9. ASP基礎(chǔ)入門第八篇(ASP內(nèi)建對(duì)象Application和Session)10. ElementUI下拉框選擇后不顯示值問題及解決
