Python ftplib模块
Posted -wenli
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Python ftplib模块相关的知识,希望对你有一定的参考价值。
Python ftplib模块
官方文档:https://docs.python.org/3/library/ftplib.html?highlight=ftplib#module-ftplib
实例:https://www.example-code.com/python/ftp.asp
ftp登陆连接 from ftplib import FTP #加载ftp模块 ftp=FTP() #设置变量 ftp.set_debuglevel(2) #打开调试级别2,显示详细信息 ftp.connect("IP","port") #连接的ftp sever和端口 ftp.login("user","password") #连接的用户名,密码 print ftp.getwelcome() #打印出欢迎信息 ftp.abort () #中止正在进行的文件传输。使用这种方法并不总是有效,但是值得一试。 ftp.sendcmd (cmd) #向服务器发送一个简单的命令字符串并返回响应字符串。 ftp.voidcmd(cmd) #向服务器发送一个简单的命令字符串并处理响应。如果接收到与成功对应的响应代码(范围为200-299),则不返回任何内容。提高error_reply否则。 ftp.retrbinary(cmd, callback, blocksize=8192, rest=None) #以二进制传输模式检索文件。cmd应该是一个适当的RETR命令:‘RETR filename‘。对于接收到的每个数据块调用回调函数,并使用一个字节参数给出数据块。可选块大小参数指定要读取的底层套接字对象的最大块大小,该套接字对象是为执行实际传输而创建的(这也是传递给回调的数据块的最大大小)。选择一个合理的默认值。rest与transfercmd()方法中的含义相同。 ftp.retrlines (cmd,callback=) #检索ASCII传输模式下的文件或目录列表。cmd应该是一个适当的RETR命令(请参阅retrbinary())或一个类似LIST或NLST的命令(通常只是字符串“LIST”)。LIST检索文件列表和有关这些文件的信息。NLST检索文件名列表。为每一行调用回调函数,其中包含一个字符串参数,该参数包含删除了尾随CRLF的行。默认回调函数将该行打印到sys.stdout。 ftp.set_pasv (val) #如果val为真,则启用“被动”模式,否则禁用被动模式。默认情况下处于被动模式。 ftp.storbinary(cmd, fp, blocksize=8192, callback=None, rest=None) #以二进制传输模式存储文件。cmd应该是一个适当的STOR命令:“STOR filename”。fp是一个文件对象(以二进制模式打开),直到EOF使用其read()方法以块大小块大小的方式提供要存储的数据为止。块大小参数默认为8192。回调是一个可选的单参数可调用,它在发送数据块之后对每个数据块调用。rest与transfercmd()方法中的含义相同。 ftp.cmd("xxx/xxx") #进入远程目录 file_handle=open(filename,"wb").write #以写模式在本地打开文件 ftp.retrbinaly("RETR filename.txt",file_handle,bufsize) #接收服务器上文件并写入本地文件 ftp.set_debuglevel(0) #关闭调试模式 ftp相关命令操作 ftp.cwd(pathname) #设置FTP当前操作的路径 ftp.dir() #显示目录下所有目录信息 ftp.nlst() #获取目录下的文件 ftp.mkd(pathname) #新建远程目录 ftp.pwd() #返回当前所在位置 ftp.rmd(dirname) #删除远程目录 ftp.delete(filename) #删除远程文件 ftp.size(文件名) #请求服务器上名为filename的文件的大小。成功时,文件大小作为整数返回,否则不返回任何值。注意,SIZE命令不是标准化的,但是许多常见的服务器实现都支持它。 ftp.rename(fromname, toname)#将fromname修改名称为toname。 ftp.storbinaly("STOR filename.txt",file_handel,bufsize) #上传目标文件 ftp.retrbinary("RETR filename.txt",file_handel,bufsize) #下载FTP文件 ftp.quit () #向服务器发送退出命令并关闭连接。这是关闭连接的“礼貌”方式,但如果服务器对QUIT命令响应错误,则可能引发异常。这意味着对close()方法的调用将使FTP实例对后续调用无效(参见下面)。 ftp.close () #单方面关闭连接。这不应该应用于已经关闭的连接,例如成功调用quit()之后。然后调用FTP实例 ftp.storlines (cmd, fp, callback=None) #以ASCII传输模式存储文件。cmd应该是一个适当的STOR命令(参见storbinary())。使用readline()方法从文件对象fp(以二进制模式打开)中读取行,直到EOF,以提供要存储的数据。回调是一个可选的单参数可调用,它在发送后的每一行上调用。 ftp.transfercmd (cmd,rest=None) #通过数据连接启动传输。如果传输活动,发送EPRT或PORT命令和cmd指定的传输命令,并接受连接。如果服务器是被动的,发送一个EPSV或PASV命令,连接到它,并启动传输命令。无论哪种方式,返回连接的套接字。如果提供了可选rest,则向服务器发送一个rest命令,并将rest作为参数传递。rest通常是请求文件中的字节偏移量,它告诉服务器在请求偏移量处重新发送文件的字节,跳过初始字节。但是请注意,RFC 959只要求rest是一个字符串,包含ASCII码33到ASCII码126之间可打印范围内的字符。因此,transfercmd()方法将rest转换为字符串,但是不检查字符串的内容。如果服务器不识别REST命令,将引发error_reply异常。如果发生这种情况,只需调用transfercmd()而不使用rest参数。 ftp.ntransfercmd (cmd,rest=None) #与transfercmd()类似,但是返回数据连接的元组和数据的期望大小。如果无法计算预期大小,则不会返回任何作为预期大小的值。cmd和rest与transfercmd()中的含义相同。 ftp.mlsd(路径= " ", facts= []) #使用MLSD命令(RFC 3659)以标准格式列出目录。如果省略path,则假定当前目录。facts是表示所需信息类型的字符串列表(例如["type"、"size"、"perm"])。返回生成器对象,该对象为path中找到的每个文件生成一个由两个元素组成的元组。第一个元素是文件名,第二个元素是包含文件名事实的字典。此字典的内容可能受到事实参数的限制,但服务器不能保证返回所有请求的事实。
FTP.quit()与FTP.close()的区别
FTP.quit():发送QUIT命令给服务器并关闭掉连接。这是一个比较“缓和”的关闭连接方式,但是如果服务器对QUIT命令返回错误时,会抛出异常。
FTP.close():单方面的关闭掉连接,不应该用在已经关闭的连接之后,例如不应用在FTP.quit()之后。
异常ftplib.error_reply #当从服务器接收到意外响应时引发异常。 异常ftplib.error_temp #当接收到表示临时错误的错误代码(范围为400-499的响应代码)时引发异常。 异常ftplib.error_perm #当接收到表示永久错误的错误代码(范围为500-599的响应代码)时引发异常。 异常ftplib.error_proto #当从服务器接收到不符合文件传输协议的响应规范(即以数字开头)的响应时,会引发异常 ftplib.all_errors #FTP实例的方法可能由于FTP连接问题(与调用方所犯的编程错误相反)而引发的所有异常的集合(作为一个元组)。这个集合包括上面列出的四个异常以及OSError。
FTP_TLS对象 #FTP_TLS类继承自FTP,定义这些附加对象: FTP_TLS.ssl_version #要使用的SSL版本(默认为SSL . protocol_sslv23)。 FTP_TLS.auth () #根据ssl_version属性中指定的内容,使用TLS或SSL设置安全控制连接。 #在3.4版中更改:该方法现在支持使用ssl.SSLContext检查主机名。check_hostname和服务器名指示(参见ssl.HAS_SNI)。 FTP_TLS.ccc () #将控制通道还原为纯文本。这对于利用防火墙非常有用,因为防火墙知道如何在不打开固定端口的情况下使用不安全的FTP处理NAT。 FTP_TLS.prot_p () #建立安全的数据连接。 FTP_TLS.prot_c () #设置明文数据连接。
(Python) FTP中的主动和被动模式 被动属性控制上传/下载的数据连接是在主动模式还是被动模式下建立的。若要使用主动模式,请设置被动属性 Passive property= False。这是默认值。若要使用被动模式,请设置被动属性 Passive property= True。 被动模式/主动模式: 主动模式: FTP客户机选择一个端口号并向FTP服务器发送一个“port”命令。然后FTP客户机在选择的端口侦听,FTP服务器发出连接请求来建立连接。数据连接从FTP服务器发出,并传入FTP客户机。 被动模式: FTP客户机向FTP服务器发送一个PASV命令。FTP服务器选择一个端口号并在PASV响应中发送它。然后FTP服务器在该端口侦听来自FTP客户机的传入连接请求。数据连接传入FTP服务器,并从FTP客户机发出。 Python模块适用于Windows, Linux, Alpine Linux, MAC OS X, Solaris, FreeBSD, OpenBSD,
import sys import chilkat ftp = chilkat.CkFtp2 () #任何字符串在前30天内解锁组件。 success = ftp.UnlockComponent(“Anything for 30-day trial”) if (success != True): print (ftp.lastErrorText ()) sys.exit () ftp.put_Hostname (“ftp.something.com”) ftp.put_Username(“测试”) ftp.put_Password(“测试”) #连接并登录到FTP服务器。 succes= ftp.Connect () if (success != True): print (ftp.lastErrorText ()) sys.exit () #使用被动模式: ftp.put_Passive(True) #使用主动模式: ftp.put_Passive(False)
下载、上传文件
#coding: utf-8 from ftplib import FTP import time import tarfile #!/usr/bin/python #-*- coding: utf-8 -*- from ftplib import FTP def ftpconnect(host, username, password): ftp = FTP() #ftp.set_debuglevel(2) #打开调试级别2,显示详细信息 ftp.connect(host, 21) #连接 ftp.login(username, password) #登录,如果匿名登录则用空串代替即可 return ftp def downloadfile(ftp, remotepath, localpath): bufsize = 1024 #设置缓冲块大小 fp = open(localpath,‘wb‘) #以写模式在本地打开文件 ftp.retrbinary(‘RETR ‘ + remotepath, fp.write, bufsize) #接收服务器上文件并写入本地文件 ftp.set_debuglevel(0) #关闭调试 fp.close() #关闭文件 def uploadfile(ftp, remotepath, localpath): bufsize = 1024 fp = open(localpath, ‘rb‘) ftp.storbinary(‘STOR ‘+ remotepath , fp, bufsize) #上传文件 ftp.set_debuglevel(0) fp.close() if __name__ == "__main__": ftp = ftpconnect("******", "***", "***") downloadfile(ftp, "***", "***") uploadfile(ftp, "***", "***") ftp.quit()
上传、下载文件/目录
#coding:utf-8 from ctypes import * import os import sys import ftplib class myFtp: ftp = ftplib.FTP() bIsDir = False path = "" def __init__(self, host, port=‘21‘): #self.ftp.set_debuglevel(2) #打开调试级别2,显示详细信息 #self.ftp.set_pasv(0) #0主动模式 1 #被动模式 self.ftp.connect( host, port ) def Login(self, user, passwd): self.ftp.login( user, passwd ) print self.ftp.welcome def DownLoadFile(self, LocalFile, RemoteFile): file_handler = open( LocalFile, ‘wb‘ ) self.ftp.retrbinary( "RETR %s" %( RemoteFile ), file_handler.write ) file_handler.close() return True def UpLoadFile(self, LocalFile, RemoteFile): if os.path.isfile( LocalFile ) == False: return False file_handler = open(LocalFile, "rb") self.ftp.storbinary(‘STOR %s‘%RemoteFile, file_handler, 4096) file_handler.close() return True def UpLoadFileTree(self, LocalDir, RemoteDir): if os.path.isdir(LocalDir) == False: return False print "LocalDir:", LocalDir LocalNames = os.listdir(LocalDir) print "list:", LocalNames print RemoteDir self.ftp.cwd( RemoteDir ) for Local in LocalNames: src = os.path.join( LocalDir, Local) if os.path.isdir( src ): self.UpLoadFileTree( src, Local ) else: self.UpLoadFile( src, Local ) self.ftp.cwd( ".." ) return def DownLoadFileTree(self, LocalDir, RemoteDir): print "remoteDir:", RemoteDir if os.path.isdir( LocalDir ) == False: os.makedirs( LocalDir ) self.ftp.cwd( RemoteDir ) RemoteNames = self.ftp.nlst() print "RemoteNames", RemoteNames print self.ftp.nlst("/del1") for file in RemoteNames: Local = os.path.join( LocalDir, file ) if self.isDir( file ): self.DownLoadFileTree( Local, file ) else: self.DownLoadFile( Local, file ) self.ftp.cwd( ".." ) return def show(self, list): result = list.lower().split( " " ) if self.path in result and "<dir>" in result: self.bIsDir = True def isDir(self, path): self.bIsDir = False self.path = path #this ues callback function ,that will change bIsDir value self.ftp.retrlines( ‘LIST‘, self.show ) return self.bIsDir def close(self): self.ftp.quit() if __name__ == "__main__": ftp = myFtp(‘*****‘) ftp.Login(‘***‘,‘***‘) ftp.DownLoadFileTree(‘del‘, ‘/del1‘)#ok ftp.UpLoadFileTree(‘del‘, "/del1" ) ftp.close() print "ok!"
注:目录内为文件,若为目录则无法传输
异常处理
#coding: utf-8 #from ftplib import FTP import ftplib import socket import os def ftpconnect(ftp_info): try: ftp = ftplib.FTP(ftp_info[0]) except (socket.error, socket.gaierror): print "ERROR: cannot reach %s" % ftp_info[0] return None username = ftp_info[1] passwd = ftp_info[2] try: ftp.login(username, passwd) except ftplib.error_perm: print "ERROR: cannot login anonymously" ftp.quit() return None return ftp if __name__ == "__main__": info_list = ["10.19.3.199", "fastupdate_amap", "@utonavi&A.map"] ftp = ftpconnect(info_list) if not ftp: exit(1) bufsize = 1024 fname = "20150416113942674.tar.gz" fp = open(os.path.join(".", fname), ‘wb‘) remotefile = os.path.join("/ADF++", fname) ftp.retrbinary("RETR " + remotefile, fp.write, bufsize) #是否有目录,没有就创建;有的话看是否有权限创建 a = ftp.dir() try: ftp.cwd("jimi") except ftplib.error_perm: try: ftp.mkd("jimi") except ftplib.error_perm: print "WARNING: U have no authority to make dir" finally: ftp.quit()
以上是关于Python ftplib模块的主要内容,如果未能解决你的问题,请参考以下文章