百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

python教程之FTP相关操作_python ftps

yuyutoo 2025-02-18 14:02 10 浏览 0 评论

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/')

相关推荐

墨尔本一华裔男子与亚裔男子分别失踪数日 警方寻人

中新网5月15日电据澳洲新快网报道,据澳大利亚维州警察局网站消息,22岁的华裔男子邓跃(Yue‘Peter’Deng,音译)失踪已6天,维州警方于当地时间13日发布寻人通告,寻求公众协助寻找邓跃。华...

网络交友须谨慎!美国犹他州一男子因涉嫌杀害女网友被捕

伊森·洪克斯克(图源网络,侵删)据美国广播公司(ABC)25日报道,美国犹他州一名男子于24日因涉嫌谋杀被捕。警方表示,这名男子主动告知警局,称其杀害了一名在网络交友软件上认识的25岁女子。雷顿警...

一课译词:来龙去脉(来龙去脉 的意思解释)

Mountainranges[Photo/SIPA]“来龙去脉”,汉语成语,本指山脉的走势和去向,现比喻一件事的前因后果(causeandeffectofanevent),可以翻译为“i...

高考重要考点:range(range高考用法)

range可以用作动词,也可以用作名词,含义特别多,在阅读理解中出现的频率很高,还经常作为完形填空的选项,而且在作文中使用是非常好的高级词汇。...

C++20 Ranges:现代范围操作(现代c++白皮书)

1.引言:C++20Ranges库简介C++20引入的Ranges库是C++标准库的重要更新,旨在提供更现代化、表达力更强的方式来处理数据序列(范围,range)。Ranges库基于...

学习VBA,报表做到飞 第二章 数组 2.4 Filter函数

第二章数组2.4Filter函数Filter函数功能与autofilter函数类似,它对一个一维数组进行筛选,返回一个从0开始的数组。...

VBA学习笔记:数组:数组相关函数—Split,Join

Split拆分字符串函数,语法Split(expression,字符,Limit,compare),第1参数为必写,后面3个参数都是可选项。Expression为需要拆分的数据,“字符”就是以哪个字...

VBA如何自定义序列,学会这些方法,让你工作更轻松

No.1在Excel中,自定义序列是一种快速填表机制,如何有效地利用这个方法,可以大大增加工作效率。通常在操作工作表的时候,可能会输入一些很有序的序列,如果一一录入就显得十分笨拙。Excel给出了一种...

Excel VBA入门教程1.3 数组基础(vba数组详解)

1.3数组使用数组和对象时,也要声明,这里说下数组的声明:'确定范围的数组,可以存储b-a+1个数,a、b为整数Dim数组名称(aTob)As数据类型Dimarr...

远程网络调试工具百宝箱-MobaXterm

MobaXterm是一个功能强大的远程网络工具百宝箱,它将所有重要的远程网络工具(SSH、Telnet、X11、RDP、VNC、FTP、MOSH、Serial等)和Unix命令(bash、ls、cat...

AREX:携程新一代自动化回归测试工具的设计与实现

一、背景随着携程机票BU业务规模的不断提高,业务系统日趋复杂,各种问题和挑战也随之而来。对于研发测试团队,面临着各种效能困境,包括业务复杂度高、数据构造工作量大、回归测试全量回归、沟通成本高、测试用例...

Windows、Android、IOS、Web自动化工具选择策略

Windows平台中应用UI自动化测试解决方案AutoIT是开源工具,该工具识别windows的标准控件效果不错,但是当它遇到应用中非标准控件定义的UI元素时往往就无能为力了,这个时候选择silkte...

python自动化工具:pywinauto(python快速上手 自动化)

简介Pywinauto是完全由Python构建的一个模块,可以用于自动化Windows上的GUI应用程序。同时,它支持鼠标、键盘操作,在元素控件树较复杂的界面,可以辅助我们完成自动化操作。我在...

时下最火的 Airtest 如何测试手机 APP?

引言Airtest是网易出品的一款基于图像识别的自动化测试工具,主要应用在手机APP和游戏的测试。一旦使用了这个工具进行APP的自动化,你就会发现自动化测试原来是如此简单!!连接手机要进行...

【推荐】7个最强Appium替代工具,移动App自动化测试必备!

在移动应用开发日益火爆的今天,自动化测试成为了确保应用质量和用户体验的关键环节。Appium作为一款广泛应用的移动应用自动化测试工具,为测试人员所熟知。然而,在不同的测试场景和需求下,还有许多其他优...

取消回复欢迎 发表评论: