Django實(shí)現(xiàn)下載超大CSV文件的示例代碼
在處理大數(shù)據(jù)集的時(shí)候,我們經(jīng)常遇到的一個(gè)問(wèn)題是內(nèi)存使用。當(dāng)我們?cè)噲D生成一個(gè)大型文件,如 CSV,并嘗試將其全部加載到內(nèi)存中時(shí),可能會(huì)遇到內(nèi)存不足的問(wèn)題。幸運(yùn)的是,Django 提供了一個(gè)解決方案:流傳輸。本文將詳細(xì)的講述如何利用 Django 進(jìn)行大型 CSV 文件的流傳輸。
流傳輸?shù)幕A(chǔ)概念
流傳輸是一種技術(shù),允許你一次發(fā)送一小部分響應(yīng),而不是一次性加載整個(gè)響應(yīng)到內(nèi)存中。這種技術(shù)對(duì)于服務(wù)大文件,如圖像,音頻和大型數(shù)據(jù)集非常有用。
創(chuàng)建 Django StreamingHttpResponse 對(duì)象
StreamingHttpResponse 對(duì)象允許我們將響應(yīng)內(nèi)容按部分,或者說(shuō)“流”的形式發(fā)送給客戶端。試看以下代碼:
from django.http import StreamingHttpResponse def big_file_download(request): def file_iterator(file_name, chunk_size=512): with open(file_name, "rb") as f: while True: c = f.read(chunk_size) if c: yield c else: break response = StreamingHttpResponse(file_iterator('big_file.csv')) return response
在這里,我們首先創(chuàng)建一個(gè)生成器函數(shù) file_iterator,它以 chunk_size 為單位讀取文件,然后用這個(gè)生成器函數(shù)作為 StreamingHttpResponse 的參數(shù),從而創(chuàng)建出一個(gè)可以流傳輸?shù)捻憫?yīng)對(duì)象。
實(shí)現(xiàn) Django 流傳輸大型 CSV 文件
現(xiàn)在,我們知道了如何創(chuàng)建 StreamingHttpResponse 對(duì)象,接著看一下如何用它來(lái)流傳輸大型 CSV 文件:
import csv from django.http import StreamingHttpResponse from .models import Person class Echo: def write(self, value): return value def streaming_csv_view(request): persons = Person.objects.all().values_list('name', 'age', 'city') pseudo_buffer = Echo() writer = csv.writer(pseudo_buffer) response = StreamingHttpResponse((writer.writerow(person) for person in persons), content_type="text/csv") response['Content-Disposition'] = 'attachment; filename="persons.csv"' return response
在上述代碼中,我們創(chuàng)建了一個(gè) Echo 類,并將其實(shí)例 pseudo_buffer 作為 csv.writer 的參數(shù)。這樣,我們可以以迭代的方式寫(xiě)入 CSV 行,而不必把它們?nèi)考虞d到內(nèi)存中。之后,我們把這個(gè) writerow 方法的迭代器作為 StreamingHttpResponse 的參數(shù)。注意,我們此時(shí)仍需要設(shè)置正確的 MIME 類型和 Content-Disposition 頭部。
總結(jié)
這就是如何使用 Django 的 StreamingHttpResponse 對(duì)象來(lái)流傳輸大型 CSV 文件。完成這個(gè)特性后,你應(yīng)該能夠更高效地處理大數(shù)據(jù)集,且大大降低了內(nèi)存使用。
到此這篇關(guān)于Django實(shí)現(xiàn)下載超大CSV文件的示例代碼的文章就介紹到這了,更多相關(guān)Django下載大文件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
django框架中ajax的使用及避開(kāi)CSRF 驗(yàn)證的方式詳解
這篇文章主要介紹了django框架中ajax的使用及避開(kāi)CSRF 驗(yàn)證的方式,結(jié)合實(shí)例形式分析了Django框架ajax后臺(tái)交互與排除驗(yàn)證csrf相關(guān)操作技巧,需要的朋友可以參考下2019-12-12python之如何使用openpyxl設(shè)置單元格樣式
這篇文章主要介紹了python之如何使用openpyxl設(shè)置單元格樣式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06Python實(shí)現(xiàn)解析參數(shù)的三種方法詳解
這篇文章主要介紹了python解析參數(shù)的三種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-07-07python 獲取文件下所有文件或目錄os.walk()的實(shí)例
下面小編就為大家分享一篇python 獲取文件下所有文件或目錄os.walk()的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-04-04python實(shí)現(xiàn)不同電腦之間視頻傳輸功能
這篇文章主要介紹了python實(shí)現(xiàn)不同電腦之間視頻傳輸,本文視頻傳輸實(shí)現(xiàn)的前提是確保發(fā)送端和接收端接在同一個(gè)局域網(wǎng)下,分為發(fā)送端和接收端,通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-06-06基于PyQt5實(shí)現(xiàn)一個(gè)無(wú)線網(wǎng)連接器
為了方便不會(huì)python的朋友也能夠使用,本文將用pyqt5將制作一個(gè)帶界面的無(wú)線網(wǎng)連接器,文中的示例代碼講解詳細(xì),感興趣的可以了解一下2022-08-08