香港云主机最佳企业级服务商!

ADSL拨号VPS包含了中国大陆(联通,移动,电信,)

中国香港,国外拨号VPS。

当前位置:云主机 > python >

电信ADSL拨号VPS
联通ADSL拨号VPS
移动ADSL拨号VPS

python网络编程之文件下载实例分析


时间:2021-12-08 14:46 作者:admin


本文实例讲述了python/' target='_blank'>python网络编程之文件下载实现方法。分享给大家供大家参考。具体如下:

真是越看越喜欢Python啊,想要了解它提供的http和ftp下载功能,原来是如此的简单。

1、相应模块

ftplib模块定义了FTP类和一些方法,用以进行客户端的ftp编程。我们可用python编写一个自已的ftp客户端程序,用于下载文件或镜像站点。如果想了解ftp协议的详细内容,请参考RFC959或是查看python帮助吧。

Urllib模块提供了非常高级的接口来从网络上抓取数据,主要使用到的是urlopen函数,跟open函数功能比较相似,这里我们要用到urlretrieve()函数来实现从http服务器上下载文件。

2、实例实现FTP下载和上传

from ftplib import FTPimport sysdef 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 FTPimport sys,osdef 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 urllibimport sysdef 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).secondsif __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程序设计有所帮助。

(责任编辑:admin)






帮助中心
会员注册
找回密码
新闻中心
快捷通道
域名登录面板
虚机登录面板
云主机登录面板
关于我们
关于我们
联系我们
联系方式

售前咨询:17830004266(重庆移动)

企业QQ:383546523

《中华人民共和国工业和信息化部》 编号:ICP备00012341号

Copyright © 2002 -2018 香港云主机 版权所有
声明:香港云主机品牌标志、品牌吉祥物均已注册商标,版权所有,窃用必究

云官方微信

在线客服

  • 企业QQ: 点击这里给我发消息
  • 技术支持:383546523

  • 公司总台电话:17830004266(重庆移动)
  • 售前咨询热线:17830004266(重庆移动)