使用Python批量下载ftp服务器中的内容

使用ftplib,轻松实现从ftp服务器上下载所需要的文件,包括目录结构等,支持了一下断点续传

 1 from ftplib import FTP
 2 import sys
 3 import os
 4 import re
 5 
 6 def ftpconnet(ftpserver,port,username,password):
 7     ftp = FTP()
 8     try:
 9         ftp.connect(ftpserver,port)
10     except:
11         raise IOError,'FTP connect failed!'
12 
13     try:
14         ftp.login(username,password)
15     except:
16         raise IOError,'FTP login failed!'
17     else:
18         return ftp
19 
20 def ftpdownload(ftp,ori_path,dest_path):
21     for each in ftp.nlst(ori_path):
22         try:
23             ftp.cwd(each)
24         except:
25             filename = re.search('\S+\/(\S+)',each).group(1)
26             local_file = dest_path + '/' + filename
27             if os.path.exists(local_file):
28                 lsize = os.stat(local_file).st_size
29                 rsize = ftp.size(each)
30                 if lsize > rsize:
31                     sys.stderr.write('the local file %s is bigger than the remote!\n'%local_file)
32                     return False
33                 elif lsize == rsize:
34                     sys.stderr.write('the file %s has been completed!\n'%local_file)
35                 bufsize = 1024 * 1024
36                 fp = open(local_file,'ab')
37                 ftp.retrbinary('RETR '+each,fp.write,bufsize,rest=lsize)
38             else:
39                 bufsize = 1024 * 1024
40                 fp = open(local_file,'wb')
41                 ftp.retrbinary('RETR '+each,fp.write,bufsize)
42         else:
43             dirname = re.search('\S+\/(\S+)',each).group(1)
44             dirname = dest_path + '/' + dirname + '/'
45             os.system('mkdir -p %s'%dirname)
46             ftpdownload(ftp,each,dirname)
47 
48 def ftpclose(ftp):
49     ftp.quit()
50 
51 if __name__ == '__main__':
52     ftp = ftpconnet('climb.genomics.cn',21,'','')
53     ftpdownload(ftp,'/pub/10.5524/100001_101000/100145/','./')
54     ftpclose(ftp)

 

转载于:https://www.cnblogs.com/lyon2014/p/4565976.html

你可以使用Pythonftplib模块来实现批量下载FTP数据。首先,你需要连接FTP服务器并进行登录。可以使用以下代码实现连接和登录: ```python from ftplib import FTP def ftpConnect(): ftp = FTP() # 实例化一个ftp对象 host = 'xxx' # FTP服务器地址 port = xxx # FTP服务器端口 user_name = 'xxx' # FTP用户名 password = 'xxx' # FTP密码 ftp.connect(host, port) # 连接FTP服务器 ftp.login(user_name, password) # 登录FTP服务器 # 打印欢迎消息 print(ftp.getwelcome()) # 设置被动模式(0是主动,1是被动) ftp.set_pasv(1) print('ftp连接成功\n') return ftp ``` 接下来,你可以使用以下代码来实现批量下载文件: ```python def ftpDownload(ftp, df): bufsize = 1024 # 设置缓冲区大小 for filename in df['filename']: # 遍历需要下载文件名列表 file_handle = open(filename, "wb").write # 以写模式在本地打开文件 ftp.retrbinary("RETR " + filename, file_handle, bufsize) # 接收服务器上文件并写入本地文件 ftp.quit() # 退出FTP服务器 ``` 在上述代码,`ftpDownload`函数接受两个参数,一个是已连接FTP对象`ftp`,另一个是包含文件名的DataFrame`df`。通过遍历`df['filename']`,我们可以逐个下载文件并保存到本地。 最后,你可以在主程序调用以上函数来执行批量下载FTP数据的操作: ```python if __name__ == '__main__': #### 引用[.reference_title] - *1* *2* *3* [实践应用|Python自动化连接FTP批量下载指定文件](https://blog.csdn.net/dxawdc/article/details/106493837)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值