中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python django下載大的csv文件實現方法分析

發布時間:2020-10-03 22:27:39 來源:腳本之家 閱讀:140 作者:zhaozhi406 欄目:開發技術

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

接手他人項目,第一個要優化的點是導出csv的功能,而且要支持比較多的數據導出,以前用php實現過,直接寫入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()
    # 寫BOM
    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

假設遍歷結果集的代碼如下:

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

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

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

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

霞浦县| 阿拉善盟| 彝良县| 绥芬河市| 休宁县| 资兴市| 宁波市| 太原市| 合作市| 万州区| 桓仁| 长葛市| 武乡县| 中牟县| 军事| 南昌县| 罗甸县| 平乡县| 新乡市| 长武县| 玛曲县| 伊宁县| 盐山县| 特克斯县| 深州市| 同心县| 碌曲县| 华池县| 马公市| 揭阳市| 齐河县| 交城县| 甘德县| 嘉黎县| 镇原县| 揭东县| 平南县| 周宁县| 岚皋县| 晋州市| 怀化市|