0
def export_csv(request):
    response = HttpResponse(mimetype = 'text/csv')
    response['Content-Disposition'] = 'attachment; filename=exported.csv'
    writer = csv.writer(response)
    data = [['First-Name','Last-name'],['Foo','baar']]
    for entry in data:
            writer.writerow(entry)
    return response

上面的代码是为从 django 输出 csv 文件而编写的。我面临的问题是导出/输出文件的内容没有显示在 csv 文件编辑器的不同框中。对于数据(列表)中的每个条目,它都打印在同一个框中,而不是它应该在不同的框中解释每个条目的值(名字,姓氏)。

csv文件中的实际结果:

|First-Name,Last-Name |
|Foor,bar             |

预期的:

|First-Name |Last-Name |
|Foo        |Baar      |

如何获得独立于列表大小及其内容导出文件的机制?

4

1 回答 1

1

您可以使用自己的自定义分隔符等为 csv.writer 设置自己的方言:

class dia2(csv.Dialect):
    delimiter = '\t' # delimiter should be only 1-char
    quotechar = '"'
    escapechar = None
    doublequote = True
    skipinitialspace = False
    lineterminator = '\r\n'
    quoting = 1
writer = csv.writer(response, dialect=dia2)
...

不同编辑器出现不同行为的主要原因 - 您应该在每个编辑器本身中正确地将 CSV 分隔符设置为您真正使用的分隔符。另一个可能的原因 - 您没有对每个 CSV 值使用引号(即 quoting=1 在方言类中)。根据您的预期输出,您还可以期待另一件事 - 每个字段的长度相同,其余部分填充空格 - 这是无法通过 csv 模块完成的,但是您可以使用将每个单元格的数据格式化为相同的长度标准的 Python 格式,例如:

data[i] = "%10s" % data[i]
于 2012-11-27T18:44:12.643 回答