网站首页 > 开源技术 正文
ftplib类库常用相关操作
import ftplib
ftp = ftplib.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文件
FTP常用操作
下面是ftp操作和使用的相关实例。
#coding:utf-8
import sys,os,ftplib,socket
HOST = '192.168.8.102' #FTP主机
user = "username"
password = "pwd"
buffer_size = 8192 #缓冲区
#连接登陆
#ftp连接函数
def connect():
try:
ftp = ftplib.FTP(HOST)
#ftp.set_debuglevel(2) #打开调试级别2,显示详细信息
ftp.login()#登录,参数user,password,acct均是可选参数,
#f.login(user="user", passwd="password")
#ftp.cmd(“xxx/xxx”) #更改远程目录
#bufsize=1024 #设置的缓冲区大小
return ftp
except (socket.error,socket.gaierror):
print("FTP登陆失败,请检查主机号、用户名、密码是否正确")
sys.exit(0)
print('已连接到: "%s"' % HOST)
#中断并退出
def disconnect(ftp):
ftp.quit() #FTP.close():单方面的关闭掉连接。FTP.quit():发送QUIT命令给服务器并关闭掉连接
#上传文件
def upload(ftp, filepath):
f = open(filepath, "rb")
file_name = os.path.split(filepath)[-1]
try:
ftp.storbinary('STOR %s'%file_name, f, buffer_size)
print('成功上传文件: "%s"' % file_name)
except ftplib.error_perm:
return False
return True
#下载文件
def download(ftp, filename):
f = open(filename,"wb").write
try:
ftp.retrbinary("RETR %s"%filename, f, buffer_size)
print('成功下载文件: "%s"' % filename)
except ftplib.error_perm:
return False
return True
#获取目录下文件或文件夹想详细信息
def listinfo(ftp):
ftp.dir()
#查找是否存在指定文件
def find(ftp,filename):
ftp_f_list = ftp.nlst() #获取目录下文件、文件夹列表
if filename in ftp_f_list:
return True
else:
return False
def main():
ftp = connect() #连接登陆ftp
dirpath = 'lp' #目录,不能使用lp/lp1这种多级创建,而且要保证你的ftp目录,右键属性不能是只读的
try: ftp.mkd(dirpath) #新建远程目录
except ftplib.error_perm:
print("目录已经存在或无法创建")
try:ftp.cwd(dirpath) #重定向到指定路径
except ftplib.error_perm:
print('不可以进入目录:"%s"' % dirpath)
print(ftp.pwd()) #返回当前所在位置
try: ftp.mkd("dir1") #在当前路径下创建dir1文件夹
except ftplib.error_perm:
print("目录已经存在或无法创建")
upload(ftp,"D:/test.txt") #上传本地文件
filename="test1.txt"
ftp.rename("test.txt", filename) #文件改名
if os.path.exists(filename): #判断本地文件是否存在
os.unlink(filename) #如果存在就删除
download(ftp,filename) #下载ftp文件
listinfo(ftp) #打印目录下每个文件或文件夹的详细信息
files = ftp.nlst() #获取路径下文件或文件夹列表
print(files)
ftp.delete(filename) #删除远程文件
ftp.rmd("dir1") #删除远程目录
ftp.quit() #退出
if __name__ == '__main__':
main()
FTP类文件
下面的代码将ftp常用的功能封装成了一个ftp类
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import ftplib
import os
import sys
class FTPSync(object):
conn = ftplib.FTP()
def __init__(self,host,port=21):
self.conn.connect(host,port)
def login(self,username,password):
self.conn.login(username,password)
self.conn.set_pasv(False)
print self.conn.welcome
def test(self,ftp_path):
print ftp_path
print self._is_ftp_dir(ftp_path)
#print self.conn.nlst(ftp_path)
#self.conn.retrlines( 'LIST ./a/b')
#ftp_parent_path = os.path.dirname(ftp_path)
#ftp_dir_name = os.path.basename(ftp_path)
#print ftp_parent_path
#print ftp_dir_name
def _is_ftp_file(self,ftp_path):
try:
if ftp_path in self.conn.nlst(os.path.dirname(ftp_path)):
return True
else:
return False
except ftplib.error_perm,e:
return False
def _ftp_list(self, line):
list = line.split(' ')
if self.ftp_dir_name==list[-1] and list[0].startswith('d'):
self._is_dir = True
def _is_ftp_dir(self,ftp_path):
ftp_path = ftp_path.rstrip('/')
ftp_parent_path = os.path.dirname(ftp_path)
self.ftp_dir_name = os.path.basename(ftp_path)
self._is_dir = False
if ftp_path == '.' or ftp_path== './' or ftp_path=='':
self._is_dir = True
else:
#this ues callback function ,that will change _is_dir value
try:
self.conn.retrlines('LIST %s' %ftp_parent_path,self._ftp_list)
except ftplib.error_perm,e:
return self._is_dir
return self._is_dir
def get_file(self,ftp_path,local_path='.'):
ftp_path = ftp_path.rstrip('/')
if self._is_ftp_file(ftp_path):
file_name = os.path.basename(ftp_path)
#如果本地路径是目录,下载文件到该目录
if os.path.isdir(local_path):
file_handler = open(os.path.join(local_path,file_name), 'wb' )
self.conn.retrbinary("RETR %s" %(ftp_path), file_handler.write)
file_handler.close()
#如果本地路径不是目录,但上层目录存在,则按照本地路径的文件名作为下载的文件名称
elif os.path.isdir(os.path.dirname(local_path)):
file_handler = open(local_path, 'wb' )
self.conn.retrbinary("RETR %s" %(ftp_path), file_handler.write)
file_handler.close()
#如果本地路径不是目录,且上层目录不存在,则退出
else:
print 'EROOR:The dir:%s is not exist' %os.path.dirname(local_path)
else:
print 'EROOR:The ftp file:%s is not exist' %ftp_path
def put_file(self,local_path,ftp_path='.'):
ftp_path = ftp_path.rstrip('/')
if os.path.isfile( local_path ):
file_handler = open(local_path, "r")
local_file_name = os.path.basename(local_path)
#如果远程路径是个目录,则上传文件到这个目录,文件名不变
if self._is_ftp_dir(ftp_path):
self.conn.storbinary('STOR %s'%os.path.join(ftp_path,local_file_name), file_handler)
#如果远程路径的上层是个目录,则上传文件,文件名按照给定命名
elif self._is_ftp_dir(os.path.dirname(ftp_path)):
print 'STOR %s'%ftp_path
self.conn.storbinary('STOR %s'%ftp_path, file_handler)
#如果远程路径不是目录,且上一层的目录也不存在,则提示给定远程路径错误
else:
print 'EROOR:The ftp path:%s is error' %ftp_path
file_handler.close()
else:
print 'ERROR:The file:%s is not exist' %local_path
def get_dir(self,ftp_path,local_path='.',begin=True):
ftp_path = ftp_path.rstrip('/')
#当ftp目录存在时下载
if self._is_ftp_dir(ftp_path):
#如果下载到本地当前目录下,并创建目录
#下载初始化:如果给定的本地路径不存在需要创建,同时将ftp的目录存放在给定的本地目录下。
#ftp目录下文件存放的路径为local_path=local_path+os.path.basename(ftp_path)
#例如:将ftp文件夹a下载到本地的a/b目录下,则ftp的a目录下的文件将下载到本地的a/b/a目录下
if begin:
if not os.path.isdir(local_path):
os.makedirs(local_path)
local_path=os.path.join(local_path,os.path.basename(ftp_path))
#如果本地目录不存在,则创建目录
if not os.path.isdir(local_path):
os.makedirs(local_path)
#进入ftp目录,开始递归查询
self.conn.cwd(ftp_path)
ftp_files = self.conn.nlst()
for file in ftp_files:
local_file = os.path.join(local_path, file)
#如果file ftp路径是目录则递归上传目录(不需要再进行初始化begin的标志修改为False)
#如果file ftp路径是文件则直接上传文件
if self._is_ftp_dir(file):
self.get_dir(file,local_file,False)
else:
self.get_file(file,local_file)
#如果当前ftp目录文件已经遍历完毕返回上一层目录
self.conn.cwd( ".." )
return
else:
print 'ERROR:The dir:%s is not exist' %ftp_path
return
def put_dir(self,local_path,ftp_path='.',begin=True):
ftp_path = ftp_path.rstrip('/')
#当本地目录存在时上传
if os.path.isdir(local_path):
#上传初始化:如果给定的ftp路径不存在需要创建,同时将本地的目录存放在给定的ftp目录下。
#本地目录下文件存放的路径为ftp_path=ftp_path+os.path.basename(local_path)
#例如:将本地文件夹a上传到ftp的a/b目录下,则本地a目录下的文件将上传的ftp的a/b/a目录下
if begin:
if not self._is_ftp_dir(ftp_path):
self.conn.mkd(ftp_path)
ftp_path=os.path.join(ftp_path,os.path.basename(local_path))
#如果ftp路径不是目录,则创建目录
if not self._is_ftp_dir(ftp_path):
self.conn.mkd(ftp_path)
#进入本地目录,开始递归查询
os.chdir(local_path)
local_files = os.listdir('.')
for file in local_files:
#如果file本地路径是目录则递归上传目录(不需要再进行初始化begin的标志修改为False)
#如果file本地路径是文件则直接上传文件
if os.path.isdir(file):
ftp_path=os.path.join(ftp_path,file)
self.put_dir(file,ftp_path,False)
else:
self.put_file(file,ftp_path)
#如果当前本地目录文件已经遍历完毕返回上一层目录
os.chdir( ".." )
else:
print 'ERROR:The dir:%s is not exist' %local_path
return
if __name__ == '__main__':
ftp = FTPSync('192.168.1.110')
ftp.login('test','test')
#上传文件,不重命名
#ftp.put_file('111.txt','a/b')
#上传文件,重命名
#ftp.put_file('111.txt','a/112.txt')
#下载文件,不重命名
#ftp.get_file('/a/111.txt',r'D:\\')
#下载文件,重命名
#ftp.get_file('/a/111.txt',r'D:\112.txt')
#下载到已经存在的文件夹
#ftp.get_dir('a/b/c',r'D:\\a')
#下载到不存在的文件夹
#ftp.get_dir('a/b/c',r'D:\\aa')
#上传到已经存在的文件夹
ftp.put_dir('b','a')
#上传到不存在的文件夹
ftp.put_dir('b','aa/B/')
猜你喜欢
- 2024-10-18 详解grafana常见报错internal server error如何解决
- 2024-10-18 tftp为何timeout?为何server error:(1)File not found
- 2024-10-18 MySQL server PID file could not be found!失败
- 2024-10-18 iis配置报错Couldnotloadfileorassemblyoroneofitsdependencie
- 2024-10-18 esp8266_server 的 streamFile 方法
- 2024-10-18 理解Python Traceback(回溯)(python 回溯法 01背包问题)
- 2024-10-18 Java IO之字节流详解,文件字节输出流,文件字节输入流
- 2024-10-18 关于k8s下使用Ingress保持长连接的异常情况排查
- 2024-10-18 僵尸毁灭工程联机教程 僵尸毁灭工程联机服务器设置
- 2024-10-18 Linux下安装mysql服务(超详细)(linux下安装mysql数据库)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)