搜尋

首頁  >  問答  >  主體

python3.x - Python3 下载rar文件 打开后出错

点击某个链接后就可以下载文件
代码如下:

import requests
import os
import urllib.request

url = 'http://www.hacker.com.cn/index.php?m=content&c=down&a=download&a_k=bd8dBFECVFYCUlUBAQJbAw5VBF0MAgJVUQIICAkPBQoGBQASBQ9VQEFfQ0UMVQwCDlVRDwEDABFZQw0NAEgKCB8EBxpQBF1AX19UF1dZUEVMFFsXF0VHQB5bUVtTA0oWUl5aGgJcSxNCDgpQVQJRXV1LUwgJBx8HBQEFFwpWCQ0BBAUBUANRVQdaVwUBSkpQSkIMV1xXXF5UDgI'
req = urllib.request.Request(url)
data = urllib.request.urlopen(req)
urllib.request.urlretrieve(url,"test.rar")

下载后打开提示如下:


于是我继续用了Requests库去下载

import requests
import os
import urllib.request

url = 'http://www.hacker.com.cn/index.php?m=content&c=down&a=download&a_k=bd8dBFECVFYCUlUBAQJbAw5VBF0MAgJVUQIICAkPBQoGBQASBQ9VQEFfQ0UMVQwCDlVRDwEDABFZQw0NAEgKCB8EBxpQBF1AX19UF1dZUEVMFFsXF0VHQB5bUVtTA0oWUl5aGgJcSxNCDgpQVQJRXV1LUwgJBx8HBQEFFwpWCQ0BBAUBUANRVQdaVwUBSkpQSkIMV1xXXF5UDgI'
f = requests.get(url)
with open("code.rar","wb") as code:
    code.write(f.content)

结果还是一样的

总结:无论是urlretrieve 还是直接open文件写入都是不对,,求解。。。
----------------------------问题已解决--------------------------------
问题反馈:
问题已解决如下:加入cookie访问下载链接,可以成功下载,附代码

import requests
import os
import re

#黑客防线杂志——杂志下载页面
info_url='http://www.hacker.com.cn/show-7-2747-1.html'

#加入headers
heads={
        'Referer': 'http://www.hacker.com.cn/show-7-2747-1.html',
        'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/39.0.2171.99 Safari/537.36 LBBROWSER'
        }
#保持cookie
s = requests.Session()
data = s.get(info_url)
data = data.text

#正则提取下载地址
pattern = re.compile('

<h5 class="tit">下载地址</h5>

.*?<li><a href=\'(.*?)\' target.*?',re.S)
download_page = re.findall(pattern,data)
download_page = download_page[0]
r= s.get(download_page)
r = r.text

#进入下载地址后,再次正则提取下载链接
pattern_down = re.compile('<a href="(.*?)" class="xzs_btn"></a>',re.S)
download_url = re.findall(pattern_down,r)
download_url = download_url[0]

download_url = 'http://www.hacker.com.cn/index.php'+download_url

file = s.get(download_url)

#二进制形式写入文件
with open('mybook.rar','wb') as code:
    code.write(file.content)
高洛峰高洛峰2777 天前795

全部回覆(2)我來回復

  • 迷茫

    迷茫2017-04-17 15:27:22

    直接用瀏覽器打開你下載的網址,發現這並不是一個rar文件哦,返回的是一個網頁

    如果這的確是一個rar檔案的話,或許需要登錄,在請求中加入COOKIE才能下載

    回覆
    0
  • 黄舟

    黄舟2017-04-17 15:27:22

    瀏覽器開啟參數錯誤,這時候,你用文字編輯器開啟就會發現是一個 HTML 檔案了

    回覆
    0
  • 取消回覆