python网络编程之文件下载实例分析
作者:久月 时间:2021-06-04 08:02:29
本文实例讲述了python网络编程之文件下载实现方法。分享给大家供大家参考。具体如下:
真是越看越喜欢python啊,想要了解它提供的http和ftp下载功能,原来是如此的简单。
1、相应模块
ftplib模块定义了FTP类和一些方法,用以进行客户端的ftp编程。我们可用python编写一个自已的ftp客户端程序,用于下载文件或镜像站点。如果想了解ftp协议的详细内容,请参考RFC959或是查看python帮助吧。
Urllib模块提供了非常高级的接口来从网络上抓取数据,主要使用到的是urlopen函数,跟open函数功能比较相似,这里我们要用到urlretrieve()函数来实现从http服务器上下载文件。
2、实例实现FTP下载和上传
from ftplib import FTP
import sys
def ftpdownload(path,file):
ftp = FTP()
ftp.set_debuglevel(2)
#打开调试级别2,显示详细信息
ftp.connect('**IP**')
#连接ftp服务器
ftp.login(user,password)
#输入用户名和密码
print ftp.getwelcome()
#显示ftp服务器的欢迎信息
ftp.cwd(path)
#选择操作目录
bufsize = 1024
#设置缓冲区大小
file_handler = open(file,'wb').write
#以写模式在本地打开文件
strBuffer = 'RETR ' + file
ftp.retrbinary(strBuffer,file_handler,bufsize)
#接收服务器上文件并写入本地文件
ftp.set_debuglevel(0) #关闭调试
ftp.quit() #退出ftp服务器
if __name__ == '__main__':
path1 = 'download/test/'
file1 = 'test1.rar'
if len(sys.argv) == 3:
try:
ftpdownload(sys.argv[1],sys.argv[2])
#命令行输入文件在ftp上的路径和文件名,
except IOError:
print "please input the correct path and filename"
else:
ftpdownload(path1,file1)
上传文件非常类似,对应的上传函数storbinary。
from ftplib import FTP
import sys,os
def ftpdownload(path,file):
ftp = FTP()
ftp.set_debuglevel(2)
ftp.connect('**IP**')
ftp.login(user,password)
print ftp.getwelcome()
ftp.cwd(path)
bufsize = 1024
file_handler = open(file,'rb')
#读方式打开上传文件
strBuffer = 'RETR ' + file
ftp.storbinary(strBuffer,file_handler,bufsize)
#上传文件
ftp.set_debuglevel(0)
ftp.quit()
if __name__ == '__main__':
path1 = 'download/test/'
file1 = '4.jpg'
if len(sys.argv) == 3:
try:
ftpdownload(sys.argv[1],sys.argv[2])
except IOError:
print "please input the correct path and filename"
else:
ftpdownload(path1,file1)
3、实例实现HTTP下载
http下载真的是超级简单,一个函数就搞定,这里通过传入要下载的地址下载文件,并计算下载时间,我想的感觉是比较笨的计算时间的方法,不知道谁有高招呢?
import urllib
import sys
def download(url):
starttime = datetime.datetime.now()
print 'download start time is %s'% starttime
urllib.urlretrieve(url,'test.exe')
#开始下载,test.exe为下载后保存的文件名
endtime = datetime.datetime.now()
print 'download end time is %s'% endtime
print 'you download the file use time %s s' % (endtime - starttime).seconds
if __name__ == '__main__':
if len(sys.argv) == 2:
try:
download(sys.argv[1])
except IOError:
print 'url not found'
else:
download('http://www.python.org/')
希望本文所述对大家的Python程序设计有所帮助。
标签:python,文件,下载
0
投稿
猜你喜欢
echarts实现晶体球面投影的实例教程
2023-09-02 10:35:12
Js-$.extend扩展方法使方法参数更灵活
2024-05-02 16:16:21
Python OpenCV调用摄像头检测人脸并截图
2022-03-19 06:29:02
制作一个更漂亮一些的多选列表框
2007-10-16 13:04:00
python获取本地计算机名字的方法
2022-01-26 10:04:32
对Python中画图时候的线类型详解
2021-02-22 00:18:43
js实现文本框宽度自适应文本宽度的方法
2024-04-19 09:52:36
Keras中的两种模型:Sequential和Model用法
2021-10-16 07:04:32
CentOS7.5 安装 Mysql8.0.19的教程图文详解
2024-01-13 07:28:26
vue如何在for循环中设置ref并获取$refs
2023-07-02 17:00:04
oracle 优化的一点体会
2009-10-02 17:59:00
树莓派实现移动拍照
2021-10-07 18:02:25
python2.7删除文件夹和删除文件代码实例
2023-06-02 14:41:17
解决django中form表单设置action后无法回到原页面的问题
2023-06-27 00:27:54
Go语言数据结构之选择排序示例详解
2024-04-26 17:25:33
python分布式计算dispy的使用详解
2021-01-14 09:15:24
解析MySQL8.0新特性——事务性数据字典与原子DDL
2024-01-28 18:36:35
Pycharm创建文件时自动生成文件头注释(自定义设置作者日期)
2023-01-19 17:02:19
JDBC如何获取数据库连接
2024-01-23 05:53:50
JavaScript给数组添加元素的6个方法
2024-04-30 08:46:47