我正在通过FTP协议连接到工作场所的一些机器人,以自动收集备份数据。脚本应该遍历所有文件夹并下载里面的所有文件。然而,当我运行下面的代码时,python脚本在第一次迭代后会离开for folder in Folder_List:
循环。这很奇怪,因为当我试图通过在终端中输入这些命令来查看错误的原因时,一切都顺利进行。
在这里注释了部分代码之后,我发现ftp.retrbinary('RETR '+ filename, file.write)
行导致循环中断。在机器人操作系统中,父文件夹是"/ROBOT";其他文件夹在里面是这样的:/ROBOT/JOB";或"/ROBOT/DAT";
from ftplib import FTP
import os
import os.path
try:
ftp = FTP('192.10.100.1')
ftp.login('user', 'password')
ftp.getwelcome()
ftp.cwd('ROBOT/')
save_dir_full = '/home/mint/Documents/robot_data'
Folder_List = ftp.nlst()
# Folder_List should be similar to this:
# Folder_List = ['JOB', 'DAT', 'CND', 'SYS', 'PRM', 'LST', 'CSV', 'LOG']
for folder in Folder_List:
if not(os.path.exists(save_dir_full +'/'+folder)):
try:
os.makedirs(save_dir_full +'/'+folder)
except:
#print('directory already exists')
pass
ftp.cwd(folder)
filenames = ftp.nlst() # get filenames within the directory
for filename in filenames:
local_filename = os.path.join(save_dir_full +'/'+folder+'/'+ filename)
file = open(local_filename, 'wb')
# THERE /
ftp.retrbinary('RETR '+ filename, file.write)
file.close()
print(filename)
ftp.cwd('..')
ftp.quit()
except:
print('Could not connect to ftp device')
在我添加了try块之后,循环没有中断,程序成功完成:
try:
ftp.retrbinary('RETR '+ filename, file.write)
except:
pass
你知道为什么它有效吗?
你知道它为什么有效吗
首先要做的是仔细观察发生了什么,要做到这一点,请替换:
try:
ftp.retrbinary('RETR '+ filename, file.write)
except:
pass
带有
try:
ftp.retrbinary('RETR '+ filename, file.write)
except Exception as e:
print(e)
并观察您的代码将产生什么。一般来说,不建议在python中使用裸except
。