【发布时间】:2018-07-25 14:39:13
【问题描述】:
我正在尝试以编程方式从网络下载“.csv”文件。我收到带有以下代码的 200 响应。
import requests
url = 'http://eoddata.com/data/filedownload.aspx?e=NYSE&sd=20180722&ed=20180722&d=5&k=xh2mnktdc4&o=d&ea=1&p=0'
user, password = '..', '..'
resp = requests.get(url, auth=(user, password))
在浏览器中提交此 URL 时,“.csv”文件会自动下载。我试图让我的应用程序在本地存储文件。我不知道文件的结束位置,所以我很难保存它。
我添加了 HTTP Live Headers 扩展,它给了我这个:
GET /data/filedownload.aspx?e=AMEX&sd=20180719&ed=20180719&d=5&k=n4vic5se64&o=d&ea=1&p=0 HTTP/1.1
Host: eoddata.com
Accept: text/css,*/*;q=0.1
Accept-Encoding: gzip, deflate
Accept-Language: en-US,en;q=0.9
Cookie: ASP.NET_SessionId=drbcwljllaf3xdwdlvqzfvl1;EODDataAdmin=01438A3826CBEEC6085BF7B27AEB1BE6AF337FFBF3E3E33AA1D882D39FB92555E8370DD45631B3F8CAD5289C5C46DB28C99B44DC8253A78D659EB165ADC55A1D6E4C20FA81051908E6BE82143EA5398662779546BE4C31C6F32833C5558F23C9A30D0CA16A703CB939FC6D77A0FB0CB017DDEEA832A1A0CC228B61777295C58CA52AF78B472B9D2FC19E78770DEBD346E9B05F02C65F96EE22C3E55B083FC4A1311FA12B223CC2899D6166E1284AD95E
DNT: 1
Referer: http://eoddata.com/download.aspx
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/67.0.3396.99 Safari/537.36
HTTP/1.1 200 OK
Cache-Control: private
content-disposition: attachment;filename="AMEX_20180719.csv"
Content-Length: 93840
Content-Type: text/plain
Date: Wed, 25 Jul 2018 13:54:31 GMT
Server: Microsoft-IIS/7.5
X-AspNet-Version: 4.0.30319
X-Powered-By: ASP.NET
非常感谢您在保存预期文件方面的任何帮助。
编辑:
我想在标题响应中指出这一行:content-disposition: attachment;filename="AMEX_20180719.csv" 这有什么不同吗?
【问题讨论】:
-
你能不能通过使用流作为参数来获取。 resp = requests.get(url, auth=(user, password), stream=True) 然后使用 iter_content() 下载块
-
我认为您的建议与@Sam 相同。如果是这样,它没有工作。内容处置是一个附件,你知道这是否有问题吗?
标签: python python-3.x authentication python-requests