爬虫--文件的下载

server.pypython

from flask import *
app=Flask(__name__)
@app.route('/')
def index():
    if  not "fileName" in request.values:
        s="图像.jpg"
        return s
    else:
        fileName=request.values.get("fileName")
        f=open(fileName,"rb")
        data=f.read()
        f.close()
        return data


if __name__=='__main__':
    app.run(port=5000,debug=True)

 

 客户端web

import urllib.request
import urllib.parse
url="http://127.0.0.1:5000"
resp=urllib.request.urlopen(url)
data=resp.read()
fileName=data.decode()

resp=urllib.request.urlopen(url+"?fileName="+urllib.parse.quote(fileName))
data=resp.read()
f=open("download"+fileName,"wb")
f.write(data)
f.close()
print(fileName,len(data))

  

 

下面对web文件下载作详细的说明flask

首先是服务器方面server.py服务器

 

from flask import *app

app=Flask(__name__)框架

@app.route('/')url

 

#上面三行属于python web的flask框架debug

 

@app.route('/')
def index():
若是fileName不在resquest.values中
if not "fileName" in request.values:
s="图像.jpg"
return s
至关于初始化的默认设置

若是存在的话以下方式处理
else:
fileName=request.values.get("fileName")
f=open(fileName,"rb")经过二进制的方式打开文件
data=f.read()读取文件
f.close()关闭文件
return data返回读取的文件


if __name__=='__main__':
app.run(port=5000,debug=True)

 

而后是客户端方面code

import urllib.request
import urllib.parse导入相关的包
url="http://127.0.0.1:5000"
resp=urllib.request.urlopen(url)
data=resp.read()
fileName=data.decode()此时得到服务器上的默认文件

resp=urllib.request.urlopen(url+"?fileName="+urllib.parse.quote(fileName))
data=resp.read()
f=open("download"+fileName,"wb")
f.write(data)
f.close()
print(fileName,len(data))
相关文章
相关标签/搜索