用python写测试脚本,从本地传文件至ftp远程路径 如何用python实现上传本地指定文件夹下文件(文件名称均为...
\u7528python\u5199\u811a\u672c\uff0c\u4ece\u672c\u5730\u4e0a\u4f20\u6587\u4ef6\u81f3ftp\u8fdc\u7a0b\u8def\u5f84\u7684\u65b9\u6cd5\uff0c\u8c22\u8c22\uff0c\u6587\u4ef6ftp\u7528FileZilla For Windows\u6bd4\u8f83\u597d\u7528\uff1b
\u8981\u662f\u6258\u7ba1\u4ee3\u7801\u7684\u8bdd\uff0c\u53ef\u4ee5\u4f7f\u7528SVN\u6216\u8005GIt\u3002
\u8fd9\u8981\u770b\u4f60\u7684\u672c\u5730\u4e0e\u8fdc\u7aef\u5141\u8bb8\u54ea\u4e9b\u901a\u4fe1\u65b9\u5f0f\uff08\u534f\u8bae\uff09
转自:http://news.tuxi.com.cn/kf/article/jhtdj.htm
本文实例讲述了python实现支持目录FTP上传下载文件的方法。分享给大家供大家参考。具体如下:
该程序支持ftp上传下载文件和目录、适用于windows和linux平台。
#!/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/')
希望本文所述对大家的Python程序设计有所帮助。
以下转自:http://blog.csdn.net/linda1000/article/details/8255771
Python中的ftplib模块
Python中默认安装的ftplib模块定义了FTP类,其中函数有限,可用来实现简单的ftp客户端,用于上传或下载文件
FTP的工作流程及基本操作可参考协议RFC959
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文件
网上找到一个具体的例子:
# 例:FTP编程
from ftplib import FTP
ftp = FTP()
timeout = 30
port = 21
ftp.connect('192.168.1.188',port,timeout) # 连接FTP服务器
ftp.login('UserName','888888') # 登录
print ftp.getwelcome() # 获得欢迎信息
ftp.cwd('file/test') # 设置FTP路径
list = ftp.nlst() # 获得目录列表
for name in list:
print(name) # 打印文件名字
path = 'd:/data/' + name # 文件保存路径
f = open(path,'wb') # 打开要保存文件
filename = 'RETR ' + name # 保存FTP文件
ftp.retrbinary(filename,f.write) # 保存FTP上的文件
ftp.delete(name) # 删除FTP文件
ftp.storbinary('STOR '+filename, open(path, 'rb')) # 上传FTP文件
ftp.quit() # 退出FTP服务器
完整的模板:
#!/usr/bin/python
# -*- coding: utf-8 -*-
import ftplib
import os
import socket
HOST = 'ftp.mozilla.org'
DIRN = 'pub/mozilla.org/webtools'
FILE = 'bugzilla-3.6.7.tar.gz'
def main():
try:
f = ftplib.FTP(HOST)
except (socket.error, socket.gaierror):
print 'ERROR:cannot reach " %s"' % HOST
return
print '***Connected to host "%s"' % HOST
try:
f.login()
except ftplib.error_perm:
print 'ERROR: cannot login anonymously'
f.quit()
return
print '*** Logged in as "anonymously"'
try:
f.cwd(DIRN)
except ftplib.error_perm:
print 'ERRORL cannot CD to "%s"' % DIRN
f.quit()
return
print '*** Changed to "%s" folder' % DIRN
try:
#传一个回调函数给retrbinary() 它在每接收一个二进制数据时都会被调用
f.retrbinary('RETR %s' % FILE, open(FILE, 'wb').write)
except ftplib.error_perm:
print 'ERROR: cannot read file "%s"' % FILE
os.unlink(FILE)
else:
print '*** Downloaded "%s" to CWD' % FILE
f.quit()
return
if __name__ == '__main__':
main()
功能测试中经常遇到编写脚本的情况,python确实不错,主要是太轻便了。
绛旓細#涓婁紶鍒濆鍖:濡傛灉缁欏畾鐨刦tp璺緞涓嶅瓨鍦ㄩ渶瑕佸垱寤,鍚屾椂灏嗘湰鍦扮殑鐩綍瀛樻斁鍦ㄧ粰瀹氱殑ftp鐩綍涓嬨 #鏈湴鐩綍涓嬫枃浠跺瓨鏀剧殑璺緞涓篺tp_path=ftp_path+os.path.basename(local_path) #渚嬪:灏嗘湰鍦版枃浠跺すa涓婁紶鍒癴tp鐨刟/b鐩綍涓,鍒欐湰鍦癮鐩綍涓嬬殑鏂囦欢灏嗕笂浼犵殑ftp鐨刟/b/a鐩綍涓 if begin: if not self._is_ftp_dir(...
绛旓細1.棣栧厛锛屽畨瑁卻elenium妗嗘灦锛岃繖涓洿鎺ュ湪cmd绐楀彛杈撳叆鍛戒护鈥減ipinstallselenium鈥濆氨琛岋紝濡備笅锛屽畨瑁呴潪甯稿揩锛2.瀹夎瀹屾垚鍚庯紝杩橀渶瑕佸畨瑁呮祻瑙堝櫒椹卞姩绋嬪簭锛屼笉鐒剁洿鎺ヨ繍琛岀▼搴忎細鎶ラ敊锛屼互璋锋瓕娴忚鍣╟hrome涓轰緥锛岄渶瑕佷笅杞絚hromedriver椹卞姩绋嬪簭锛屽涓嬶紝杩欓噷chromedriver鐨勭増鏈繀椤昏涓庤嚜宸卞钩鍙版祻瑙堝櫒鐨勭増鏈尮閰嶏細涓嬭浇瀹屾垚鍚庯紝鏄...
绛旓細Python鐗堟湰寤鸿閫夋嫨3.7锛屼笅杞藉畨瑁呮椂鍕鹃夎嚜鍔ㄦ坊鍔犲埌绯荤粺璺緞锛岃繖鏍峰湪鍚庣画鐨鑴氭湰缂栧啓涓細鏇村姞渚挎嵎銆傜劧鍚庯紝鐢╬ip3鏉ュ畨瑁匒ppium-Python-Client锛岃繖鏄疨ython涓嶢ppium浜や簰鐨勬ˉ姊併傚疄鎴樻紨绀 璁剧疆瀹屾垚鍚庯紝鎴戜滑鏉ョ湅涓涓叿浣撶殑绀轰緥锛氬紑鍙戜竴涓猀Q搴旂敤鐧诲綍鑴氭湰銆傚湪妯℃嫙鍣ㄤ腑鍚姩搴旂敤锛岄氳繃Python鑴氭湰鎺у埗鐐瑰嚮鐧诲綍鎸夐挳锛岃緭鍏ヨ处...
绛旓細1 PythonInterpreter interpreter = new PythonInterpreter();2 InputStream filepy = new FileInputStream("D:\\demo.py");3 interpreter.execfile(filepy); ///鎵цpython py鏂囦欢 4 filepy.close();3. 浣跨敤Runtime.getRuntime()鎵ц鑴氭湰鏂囦欢 杩欑鏂瑰紡鍜.net涓嬮潰璋冪敤cmd鎵ц鍛戒护鐨勬柟寮忕被浼笺傚鏋滄墽...
绛旓細杩欓噷鎴浣跨敤python鑷甫鐨処DLE杩涜缂栧啓娴嬭瘯鑴氭湰锛鎵撳紑python鏂囦欢鎵惧埌IDLE锛坧ython GUI锛夊弻鍑绘墦寮锛屽鍥撅細4.绠鍗曚粙缁島nittest妗嗘灦鐨勪娇鐢ㄦ柟娉 -*- coding:utf-8 -*- from uiautomator import device as d import unittest class Mytest(unittest.TestCase):鍒濆鍖栧伐浣 def setUp(self):print "---鍒濆鍖栧伐浣...
绛旓細涓銆侀鍏堣璇存墜鏈鸿嚜鍔ㄥ寲娴嬭瘯鐨勫師鐞1銆佹墜鏈鸿嚜鍔ㄥ寲娴嬭瘯鐨勫師鐞嗕负PC涓婁竴涓帶鍒剁锛堟祴璇曞伐鍏凤級涓庢墜鏈轰笂鐨勪竴涓猘gent绔紝閫氳繃涓插彛銆乁SB鎴栬呮棤绾挎柟寮忓皢PC涓庢墜鏈虹粓绔浉杩烇紝鐒跺悗搴旂敤娴嬭瘯宸ュ叿鍚戞墜鏈哄彂閫佽姹傛垨鑰呭懡浠わ紝鎵嬫満鏀跺埌鍛戒护鎴栬呰姹傚悗锛屼氦缁檃gent绔В鏋愶紝鐒跺悗agent灏嗚繖浜涜В鏋愮殑鍛戒护涓嬪彂缁欐墜鏈虹殑鍚勪釜鍔熻兘妯″潡鎵鑳...
绛旓細2 鑷姩鍖栨祴璇曠殑鎵ц姝ラ 姣忔鑴氭湰閮芥槸浠庝竴涓粺涓鐨勬枃浠跺紑濮嬫墽琛岀殑,灏辨槸濡備笂鐨凷tart.py銆傝繖鏍峰仛鐨勫ソ澶勬槸鍙互鎶婃瘡涓剼鏈兘闇瑕佸鐞嗙殑宸ヤ綔鏀惧埌涓涓枃浠朵腑鍘绘墽琛,渚嬪鏀堕泦涓浜涢厤缃俊鎭,璇诲彇鍛戒护琛屽弬鏁般備互杩欐牱缁熶竴鐨勫鐞嗛鏍间负鑴氭湰鐨勫彲璇绘ф彁渚涗簡淇濊瘉,涔熶负绠鍖栦簡娴嬭瘯鑴氭湰鐨缂栧啓,涓嶇敤姣忔閮借澶勭悊涓浜涘熀鏈殑...
绛旓細4銆丳ython鍗曞厓娴嬭瘯妗嗘灦锛岀綉缁滈氫俊鍗忚锛孒TTP涓嶩TTPS鍗忚锛學ebService涓嶹ebSocket鍗忚锛Python鐨鎺ュ彛娴嬭瘯搴擄紝PostMan涓嶴oapUI鎺ュ彛娴嬭瘯宸ュ叿閫氳繃瀵逛唬鐮佺骇鎺ュ彛娴嬭瘯鍜屽崗璁骇鎺ュ彛娴嬭瘯鐨勬祴璇曞紑鍙戝疄鎴橈紝鐏垫椿杩愮敤Python寮鍙戞帴鍙娴嬭瘯鑴氭湰锛鐔熺粌杩愮敤鍚勭被鎺ュ彛娴嬭瘯宸ュ叿銆5銆佹ц兘娴嬭瘯鍘熺悊锛屾寚鏍囦綋绯伙紝鍦烘櫙璁捐锛屽疄鏂借繃绋嬶紝JMeter宸ュ叿...
绛旓細姣斿request涓璬ata鐨勮竟鐣屽娴嬭瘯銆佸瓧绗︽祴璇曘侀潪绌轰负绌烘祴璇曠瓑绛夛紝閮藉彲浠ュ仛 浜屻乁I鑷姩鍖栨祴璇曪細html椤甸潰锛python+selenium锛夋垨鑰呬竴浜涘畨鍗揳pp(python+appiun)鍙互鐢ㄣ備富瑕佹槸椤甸潰鍏冪礌鐨勬鏌ャ佽緭鍏ョ瓑銆傛瘮濡傚彲浠ュ啓涓涓鑴氭湰锛鑷姩鐧诲綍鐧惧害椤甸潰锛屾悳绱㈡煇涓涓叧閿瓧锛屽苟涓旇幏寰楁鍏抽敭瀛楃殑鐧惧害鎼滅储鏁伴噺銆
绛旓細pattern="test_add_*.py")#3.璁茶幏鍙栫殑鑴氭湰鍔犲叆鍒娴嬭瘯闆嗗悎#鍒涘缓涓涓祴璇曢泦鍚坰uite=unittest.TestSuite()#寰幆閬嶅巻discv鍒楄〃涓剼鏈殑鍚嶅瓧,骞跺姞鍏ュ埌suite涓璮or case in discv:#print casesuite.addTest(case)#璁叉祴璇曢泦杩斿洖return suitedef report_design():global filename,runner,file1now=time....