• 技术文章 >后端开发 >Python教程

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

    2016-06-06 11:16:41原创684
    本文实例讲述了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程序设计有所帮助。

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:Python中List.index()方法的使用教程 下一篇:Python操作列表之List.insert()方法的使用
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• 详细解析python正则表达式re模块• 一文搞定Python中pip的安装与使用• Python实战解析selenium的基本元素与键盘鼠标模拟事件• 一文详解python生成器• 一起聊聊Python的编码样式
    1/1

    PHP中文网