Python标准库 - ftplib模块
说明:Python中默认安装的ftplib模块定义了FTP类,可用来实现简单的ftp客户端,用于上传或下载文件。
ftplib模块常用方法:
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.cmd("xxx/xxx") #进入远程目录 bufsize=1024 #设置的缓冲区大小 filename="filename.txt" #需要下载的文件 file_handle=open(filename,"wb").write #以写模式在本地打开文件 ftp.retrbinaly("RETR filename.txt",file_handle,bufsize) #接收服务器上文件并写入本地文件 ftp.set_debuglevel(0) #关闭调试模式 ftp.quit() #退出ftp ftp相关命令操作 ftp.cwd(pathname) #设置FTP当前操作的路径 ftp.dir() #显示目录下所有目录信息 ftp.nlst() #获取目录下的文件 ftp.mkd(pathname) #新建远程目录 ftp.pwd() #返回当前所在位置 ftp.rmd(dirname) #删除远程目录 ftp.delete(filename) #删除远程文件 ftp.rename(fromname, toname)#将fromname修改名称为toname。 ftp.storbinaly("STOR filename.txt",file_handel,bufsize) #上传目标文件 ftp.retrbinary("RETR filename.txt",file_handel,bufsize) #下载FTP文件
ftplib模块的连接,文件上传,文件下载:
#!/usr/bin/env python # -*- coding: utf-8 -*- from ftplib import FTP from ftplib import error_perm host = '127.0.0.1' username = '******' password = '******' port = 21 def ftpconnect(host, port, username, password): ftp = FTP() # ftp.set_debuglevel(2) # 打开调试级别2,显示详细信息 # ftp.encoding = 'utf-8' # 解决中文编码问题,默认是latin-1 try: ftp.connect(host, port) # 连接 ftp.login(username, password) # 登录,如果匿名登录则用空串代替即可 print ftp.getwelcome() # 打印欢迎信息 except(socket.error, socket.gaierror): # ftp 连接错误 print "ERROR: cannot connect [{}:{}]" .format(host, port) return None except error_perm: # 用户登录认证错误 print "ERROR: user Authentication failed " return None return ftp # 获取/mcl下的文件 def get_ftp_file(ftp_conn, ftp_path): return ftp_conn.nlst(ftp_path) # 判断文件在ftp服务器下是否存在 def is_ftp_file(ftp_conn, ftp_path): try: if ftp_path in ftp_conn.nlst(os.path.dirname(ftp_path)): return True else: return False except error_perm: return False # 下载文件 def downloadfile(ftp, remotepath, localpath): bufsize = 1024 # 设置缓冲块大小 fp = open(localpath, 'wb') # 以写模式在本地打开文件 # 接收服务器上文件并写入本地文件 # ftp.retrbinary('RETR ' + remotepath.decode('utf-8').encode('GBK'), fp.write, bufsize) # 文件路径中文 ftp.retrbinary('RETR ' + remotepath, fp.write, bufsize) # 文件路径英文 print 'download file complete', localpath ftp.set_debuglevel(0) # 关闭调试 fp.close() # 关闭文件 ftp.quit() # 退出ftp服务器 # 上传文件 def uploadfile(ftp, remotepath, localpath): bufsize = 1024 # 设置缓冲块大小 fp = open(localpath, 'rb') # 以读模式在本地打开文件 # ftp.storbinary('STOR ' + remotepath.decode('utf-8').encode('GBK'), fp, bufsize) # 文件路径中文 ftp.storbinary('STOR ' + remotepath, fp, bufsize) # 文件路径英文 print 'upload file complete', remotepath ftp.set_debuglevel(0) # 关闭调试 fp.close() # 关闭文件 ftp.quit() # 退出ftp服务器 if __name__ == '__main__': ftp = ftpconnect(host, port, username, password) print get_ftp_file(ftp, '/mcl') # downloadfile(ftp, "/mcl/ftp_mcl.txt", "mcl.txt") # 将ftp下文件/mcl/ftp_mcl.txt下载到本地命名为mcl.txt # uploadfile(ftp, "/mcl/ftp_mcl.txt", "mcl.txt") # 将本地文件mcl.txt上传到ftp路径/mcl下命名为ftp_mcl.txt # downloadfile(ftp, "/中文名称/ftp_mcl.txt", "mcl.txt") # uploadfile(ftp, "/中文名称/ftp_mcl.txt", "mcl.txt")
FTP.quit()与FTP.close()的区别
FTP.quit():发送QUIT命令给服务器并关闭掉连接。这是一个比较“缓和”的关闭连接方式,但是如果服务器对QUIT命令返回错误时,会抛出异常。 FTP.close():单方面的关闭掉连接,不应该用在已经关闭的连接之后,例如不应用在FTP.quit()之后。一个一个一个
一个略有B格的写法获取ftp下文件
#!/usr/bin/env python # -*- coding: utf-8 -*- import ftplib # 加载ftp模块 class Ftp(object): def __init__(self, ip, port=21, username=None, passwd=None, path=None, **kwargs): self.ip = ip try: self.port = int(port) except ValueError: raise self.username = username or "" self.passwd = passwd or "" self.default_path = path or "/" self.ftp = ftplib.FTP() self.ftp.connect(ip, port, timeout=5) self.ftp.login(self.username, self.passwd) self.root_path = self.ftp.pwd() self.ftp.cwd(self.default_path) def getfiles(self): return self.ftp.nlst() # 获取文件 if __name__ == '__main__': try: FTP_file = Ftp('127.0.0.1', 21, '******', '******', '/mcl') print FTP_file.getfiles() except Exception as e: print e