欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python django下載大的csv文件實現(xiàn)方法分析

 更新時間:2019年07月19日 11:41:35   作者:zhaozhi406  
這篇文章主要介紹了python django下載大的csv文件實現(xiàn)方法,結(jié)合實例形式分析了Django框架下載csv大文件的相關(guān)操作技巧與注意事項,需要的朋友可以參考下

本文實例講述了python django下載大的csv文件實現(xiàn)方法。分享給大家供大家參考,具體如下:

接手他人項目,第一個要優(yōu)化的點是導(dǎo)出csv的功能,而且要支持比較多的數(shù)據(jù)導(dǎo)出,以前用php實現(xiàn)過,直接寫入php://output就行了,django怎么做呢?如下:

借助django的StreamingHttpResponse和python的generator

def outputCSV(rows, fname="output.csv", headers=None):
  def getContent(fileObj):
    fileObj.seek(0)
    data = fileObj.read()
    fileObj.seek(0)
    fileObj.truncate()
    return data
  def genCSV(rows, headers):
    # 準備輸出
    output = cStringIO.StringIO()
    # 寫B(tài)OM
    output.write(bytearray([0xFF, 0xFE]))
    if headers != None and isinstance(headers, list):
      headers = codecs.encode("\t".join(headers) + "\n", "utf-16le")
      output.write(headers)
      yield getContent(output)
    for row in rows:
      rowData = codecs.encode("\t".join(row) + "\n", "utf-16le")
      output.write(rowData)
      yield getContent(output) #因為StreamingHttpResponse需要一個Iterator
    output.close()
  resp = StreamingHttpResponse(genCSV(rows, headers))
  resp["Content-Type"] = "application/vnd.ms-excel; charset=utf-16le"
  resp["Content-Type"] = "application/octet-stream"
  resp["Content-Disposition"] = "attachment;filename=" + fname
  resp["Content-Transfer-Encoding"] = "binary"
  return resp

假設(shè)遍歷結(jié)果集的代碼如下:

headers = ["col1", "col2", ..., "coln"]
def genRows():
      for obj in objList:
        yield [obj.col1, obj.col2, ...obj.coln]   
#這樣調(diào)用,返回response
return outputCSV(genRows(), "file.csv", headers)

有人可能會問,為什么不用python自帶的csv.writer?因為生成的csv兼容不太好啊,關(guān)于csv的兼容性,可以看前面這篇避免UTF-8的csv文件打開中文出現(xiàn)亂碼的方法。

參考:http://stackoverflow.com/questions/5146539/streaming-a-csv-file-in-django

希望本文所述對大家基于Django框架的Python程序設(shè)計有所幫助。

相關(guān)文章

  • 詳解python中的 is 操作符

    詳解python中的 is 操作符

    is 操作符是Python語言的一個內(nèi)建的操作符。它的作用在于比較兩個變量是否指向了同一個對象。下面通過本文給大家詳細介紹python中的 is 操作符,需要的朋友參考下吧
    2017-12-12
  • Python做智能家居溫濕度報警系統(tǒng)

    Python做智能家居溫濕度報警系統(tǒng)

    本文為大家?guī)砹薖ython通過HTTP協(xié)議做一個廉價的溫濕度報警系統(tǒng)。感興趣的朋友跟隨小編一起看看吧
    2018-09-09
  • Python NumPy實現(xiàn)數(shù)組排序與過濾示例分析講解

    Python NumPy實現(xiàn)數(shù)組排序與過濾示例分析講解

    NumPy是Python的一種開源的數(shù)值計算擴展,它支持大量的維度數(shù)組與矩陣運算,這篇文章主要介紹了使用NumPy實現(xiàn)數(shù)組排序與過濾的方法,需要的朋友們下面隨著小編來一起學(xué)習吧
    2023-05-05
  • 基于Python制作打地鼠小游戲

    基于Python制作打地鼠小游戲

    這篇文章主要為大家介紹了如何利用Python實現(xiàn)打地鼠小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • django admin組件使用方法詳解

    django admin組件使用方法詳解

    這篇文章主要介紹了django admin組件使用方法詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友可以參考下
    2019-07-07
  • python實現(xiàn)計算圖形面積

    python實現(xiàn)計算圖形面積

    這篇文章主要為大家詳細介紹了python實現(xiàn)計算圖形面積,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-02-02
  • python cookie反爬處理的實現(xiàn)

    python cookie反爬處理的實現(xiàn)

    這篇文章主要介紹了python cookie反爬處理的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2020-11-11
  • python實現(xiàn)將多個文件分配到多個文件夾的方法

    python實現(xiàn)將多個文件分配到多個文件夾的方法

    今天小編就為大家分享一篇python實現(xiàn)將多個文件分配到多個文件夾的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • 在python中修改.properties文件的操作

    在python中修改.properties文件的操作

    這篇文章主要介紹了在python中修改.properties文件的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • python刪除列表中特定元素的幾種方法

    python刪除列表中特定元素的幾種方法

    這篇文章主要介紹了python刪除列表中特定元素的幾種方法,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價價值,需要的小伙伴可以參考一下
    2022-05-05

最新評論