Como una forma más limpia de hacerlo, puede registrar un procesador.
En la configuración de su puesta en marcha, añadir:
config.add_renderer(name='csv',
factory='mypackage.renderers.CSVRenderer')
después en mypackage/renderers.py
:
class CSVRenderer(object):
def __init__(self, info):
pass
def __call__(self, value, system):
fout = StringIO.StringIO()
writer = csv.writer(fout, delimiter=';', quoting=csv.QUOTE_ALL)
writer.writerow(value['header'])
writer.writerows(value['rows'])
resp = system['request'].response
resp.content_type = 'text/csv'
resp.content_disposition = 'attachment;filename="report.csv"'
return fout.getvalue()
Después de eso, se puede decorar su vista con el procesador:
@view_config(..., renderer='csv')
def myview(self):
header = ['name', 'surname', 'address']
rows = [
(
row['name'],
row['surname'],
row['address'],
)
for row in query_rows(.....)
]
return {
'header': header,
'rows': rows
}
La ventaja de este enfoque es un mejor código de vista comprobable (solo verifica el valor del diccionario) s, no hay necesidad de analizar cualquier cosa) y también se puede añadir un XLS o lo que sea Traducir al mismo punto de vista:
@view_config(..., renderer='xls')
@view_config(..., renderer='csv')
def myview(self):
...
++ HTTP 101 FTW –