如何使用Django Admin管理后臺導入CSV
假設你需要允許在Hero管理頁面上導入CSV數據。為此,您需要添加一個指向更改Hero列表頁面的鏈接,點擊這個鏈接會跳轉到上傳頁面。你需要編寫一個處理POST請求的方法,來從CSV文件中獲取數據對象:
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 )
然后創建模板文件entities/heroes_changelist.html,以覆蓋原有的admin/change_list.html:
{% extends ’admin/change_list.html’ %}{% block object-tools %} <a href='http://m.cgvv.com.cn/bcjs/import-csv/' rel='external nofollow' >Import CSV</a> <br /> {{ block.super }}{% endblock %}
最后,創建上傳頁面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 %}
修改完后,會在更改Hero后臺列表頁面上會有一個Import CSV的鏈接.
點擊后上傳頁面顯示如下。
以上就是如何使用Django Admin管理后臺導入CSV的詳細內容,更多關于Django Admin導入CSV的資料請關注好吧啦網其它相關文章!
相關文章:
1. Android打包篇:Android Studio將代碼打包成jar包教程2. Python使用urlretrieve實現直接遠程下載圖片的示例代碼3. SpringBoot+TestNG單元測試的實現4. Springboot 全局日期格式化處理的實現5. vue實現web在線聊天功能6. 解決Android Studio 格式化 Format代碼快捷鍵問題7. 完美解決vue 中多個echarts圖表自適應的問題8. JavaScript實現頁面動態驗證碼的實現示例9. Java使用Tesseract-Ocr識別數字10. JavaEE SpringMyBatis是什么? 它和Hibernate的區別及如何配置MyBatis
