在App Engine上为用户生成的csv文件创建下载链接

时间:2013-07-10 21:24:17

标签: python google-app-engine download

我在尝试创建下载链接时遇到问题,该链接将(1)原位生成CSV文件,(2)自动开始下载而不会被重定向到另一个页面(即AJAX请求)。

发生的情况如下:我没有看到任何JavaScript错误,处理程序CSVDownload也没有任何问题。但是,下载永远不会开始。出于某种原因,如果我只输入URL(..website ../ csvdownload),那么它确实使用相同的处理程序创建文件。知道为什么会这样吗?

非常感谢任何帮助!

HTML

<button id="mainReportDownload" type="button">
   Download Report
</button>

AJAX请求

$('#mainReportDownload').on('click', function() {
  $.ajax({
    type: 'GET',
    url: "/csvdownload",
    beforeSend: function() {
      notification('Creating report..','info',false)
    }
  });
});

的Python

def List2CSV(data):
  csv = ""
  for row in data:
    for item in row:
      csv = csv + item + ','
    csv = csv[:-1] + '\n'
  csv = csv[:-1]
  return csv

class CSVDownload(webapp2.RequestHandler):
  def get(self):

    conn = rdbms.connect(instance=_INSTANCE_NAME, database='test')
    cursor = conn.cursor()

    cursor.execute('SELECT email FROM Test LIMIT 100')
    testvalues = [[item for item in row] for row in cursor.fetchall()]
    csv = List2CSV(testvalues)

    self.response.headers['Content-Type'] = 'text/csv'
    self.response.headers['Content-Disposition'] = 'attachment; filename=report.csv'
    self.response.out.write(csv)
    conn.close()

1 个答案:

答案 0 :(得分:1)

你有相互矛盾的要求。当浏览器导航到发送回“附件”内容处置的URL时,会发生正常下载。但是你正在尝试使用Ajax,它不会导航,因此无法完成下载。 Ajax正在愉快地阅读内容,但之后只是将其丢弃,因为您没有定义成功处理程序,告诉它如何处理它。当然,即使您确实定义了该处理程序,出于明显的安全原因,Javascript也无法将文件保存到用户的计算机中。