接手他人项目,第一个要优化的点是导出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.