Django實現(xiàn)下載超大CSV文件的示例代碼
在處理大數(shù)據(jù)集的時候,我們經(jīng)常遇到的一個問題是內(nèi)存使用。當(dāng)我們試圖生成一個大型文件,如 CSV,并嘗試將其全部加載到內(nèi)存中時,可能會遇到內(nèi)存不足的問題。幸運的是,Django 提供了一個解決方案:流傳輸。本文將詳細的講述如何利用 Django 進行大型 CSV 文件的流傳輸。
流傳輸?shù)幕A(chǔ)概念
流傳輸是一種技術(shù),允許你一次發(fā)送一小部分響應(yīng),而不是一次性加載整個響應(yīng)到內(nèi)存中。這種技術(shù)對于服務(wù)大文件,如圖像,音頻和大型數(shù)據(jù)集非常有用。
創(chuàng)建 Django StreamingHttpResponse 對象
StreamingHttpResponse 對象允許我們將響應(yīng)內(nèi)容按部分,或者說“流”的形式發(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)建一個生成器函數(shù) file_iterator,它以 chunk_size 為單位讀取文件,然后用這個生成器函數(shù)作為 StreamingHttpResponse 的參數(shù),從而創(chuàng)建出一個可以流傳輸?shù)捻憫?yīng)對象。
實現(xiàn) Django 流傳輸大型 CSV 文件
現(xiàn)在,我們知道了如何創(chuàng)建 StreamingHttpResponse 對象,接著看一下如何用它來流傳輸大型 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)建了一個 Echo 類,并將其實例 pseudo_buffer 作為 csv.writer 的參數(shù)。這樣,我們可以以迭代的方式寫入 CSV 行,而不必把它們?nèi)考虞d到內(nèi)存中。之后,我們把這個 writerow 方法的迭代器作為 StreamingHttpResponse 的參數(shù)。注意,我們此時仍需要設(shè)置正確的 MIME 類型和 Content-Disposition 頭部。
總結(jié)
這就是如何使用 Django 的 StreamingHttpResponse 對象來流傳輸大型 CSV 文件。完成這個特性后,你應(yīng)該能夠更高效地處理大數(shù)據(jù)集,且大大降低了內(nèi)存使用。
到此這篇關(guān)于Django實現(xiàn)下載超大CSV文件的示例代碼的文章就介紹到這了,更多相關(guān)Django下載大文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
django框架中ajax的使用及避開CSRF 驗證的方式詳解
這篇文章主要介紹了django框架中ajax的使用及避開CSRF 驗證的方式,結(jié)合實例形式分析了Django框架ajax后臺交互與排除驗證csrf相關(guān)操作技巧,需要的朋友可以參考下2019-12-12python之如何使用openpyxl設(shè)置單元格樣式
這篇文章主要介紹了python之如何使用openpyxl設(shè)置單元格樣式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06Python實現(xiàn)解析參數(shù)的三種方法詳解
這篇文章主要介紹了python解析參數(shù)的三種方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2022-07-07python 獲取文件下所有文件或目錄os.walk()的實例
下面小編就為大家分享一篇python 獲取文件下所有文件或目錄os.walk()的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04