我正在尝试将一些搜索结果写入 CSV 文件,但能够将某些字段留空。现在它正在写入整个搜索字符串,但这是我发现在没有字段时处理错误的唯一方法。
这是我的代码:
if request.POST:
if request.POST.get('search_type_id') == "1":
response = HttpResponse(content_type='text/csv')
response['Content-Disposition'] = 'attachment; filename="Report Results.csv"'
export_data = request.session['report_results']
report_results = Tree.objects.filter(id__in=[instance['id'] for instance in export_data]).order_by('-created_at')
writer = csv.writer(response)
writer.writerow(['Tree ID', 'Int ID', 'Site Address', 'Site Street', 'Date Planted'])
for obj in report_results:
writer.writerow([
[obj.id_shared, ''],
[obj.id_int, ''],
[obj.planting_site.site_address, ''],
[obj.planting_site.site_street, ''],
[obj.planted_date, '']
])
return response
现在,我的 CSV 返回空字段的帐户,但给我一个 [250264, ''] 作为树 ID,例如。有没有办法告诉它在没有任何内容的情况下替换空白(例如,没有 obj.planting_site.site_address)?
在对从另一个站点提取的 JSON 结果执行此操作时,我一直在执行 obj.get('tree_id', ''),但当对象是内部保存的模型时,我无法执行此操作。
最佳答案
尝试这样的事情。
writer.writerow([
obj.id_shared or '',
obj.id_int or '',
obj.planting_site.site_address or '',
obj.planting_site.site_street or '',
obj.planted_date or ''
])
如果对象属性为空,则 or 条件将导致将空白写入文件
关于python - Django 写入带有一些空字段的 csv,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40476584/