使用Python玩转ftplib库:实现ftp文件传输自动化全攻略
itomcoil 2025-08-05 18:54 1 浏览
大家好!在日常工作中都会使用到ftp功能,用于上传和下载文件等,本章主要介绍Python的标准库ftplib来实现FTP文件传输,帮助我们实现ftp自动化。
一、ftplib库核心函数速查表
1 连接与登录
#非加密传输
from ftplib import FTP
# 创建FTP对象
ftp = FTP()
# 连接服务器,ftp默认端口为21
ftp.connect(host='168.0.0.1', port=21)
# 登录认证,输入正确的用户名和密码
ftp.login(user='your_username', passwd='your_password')
# 操作完成后,安全退出连接
ftp.quit()
#使用FTPS加密连接,加密传输,防止数据泄露。
from ftplib import FTP_TLS
ftps = FTP_TLS('secure.example.com')
ftps.login(user='admin', passwd='secret')
ftps.prot_p() # 启用加密数据通道
说明:通过FTP()创建对象,connect方法指定服务器地址和端口建立连接,login方法输入用户名和密码完成认证,操作结束后用quit方法关闭连接,避免资源浪费。
2 目录操作
# 获取当前所在目录
current_dir = ftp.pwd()
print(f"当前目录: {current_dir}")
# 切换到目标目录
ftp.cwd('/remote/files')
# 在服务器上创建新目录
ftp.mkd('new_folder')
# 删除空目录,注意目录必须为空才能删除成功
ftp.rmd('old_folder')
3 文件上传下载
1)上传文件
# 以二进制模式上传文件,适用于图片、压缩包等非文本文件
with open('local_file.zip', 'rb') as f:
ftp.storbinary('STOR remote_file.zip', f)
# 以ASCII模式上传文本文件,如txt,log,html,xml等,保证文本格式正确
with open('readme.txt', 'r') as f:
ftp.storlines('STOR readme.txt', f)
说明:'STOR remote_file.zip'中的STOR是标准化写法,后面跟的是要上传的文件。
2)下载文件
# 以二进制模式下载文件,将服务器文件保存到本地,第二个参事室回调函数
with open('local.zip', 'wb') as f:
ftp.retrbinary('RETR remote.zip', f.write)
#传输大文件时,合理设置缓冲区大小能提升传输效率:
# 设置缓冲区大小为1MB,可根据实际情况调整
BUFFER_SIZE = 1024 * 1024
# 使用设置好的缓冲区大小下载大文件
with open('large_file.iso', 'wb') as f:
ftp.retrbinary('RETR large_file.iso', f.write, blocksize=BUFFER_SIZE)
# 以文本模式下载文件,将服务器文件保存到本地
with open('local.txt', 'wb') as f:
ftp.retrlines('RETR remote.txt', f.write)
说明:'STOR remote_file.zip'中的STOR是标准化写法,后面跟的是要上传的文件。
在实际使用中,下载文本文件时,可能会遇到转换换行符失败的情况,多行的文件下载后变为了一行。
此时可以自己重写回调函数,在每一行末尾加上换行符,如下:
def write(line):
f.write(line + '\n')
# 以文本模式下载文件,将服务器文件保存到本地 回调函数为自己定义的write函数
with open('local.txt', 'wb') as f:
ftp.retrlines('RETR remote.txt', write)
4 文件管理
对服务器上的文件进行管理,这些函数能满足你的常见需求:
# 删除远程服务器上的指定文件
ftp.delete('obsolete_file.txt')
# 重命名文件,方便文件整理
ftp.rename('old_name.txt', 'new_name.txt')
# 获取文件大小,了解文件占用空间
size = ftp.size('large_file.iso')
print(f"文件大小: {size} 字节")
5 目录列表
查看服务器目录内容,这几种方式能让你快速获取文件信息:
# 获取简洁的文件列表
files = ftp.nlst()
print("目录内容:", files)
# 获取详细文件列表,直接打印到控制台
ftp.dir()
# 解析详细列表,获取文件名和类型
ftp.mlsd()
高级操作
# 设置编码
ftp.encoding = 'utf-8'
# 设置传输模式
ftp.set_pasv(True) # 被动模式(推荐)
# 发送自定义命令
response = ftp.sendcmd('HELP') # 获取服务器支持的命令
print("服务器支持命令:", response)
# 获取文件修改时间
mod_time = ftp.sendcmd('MDTM config.ini')
print(f"最后修改时间: {mod_time[4:]}")
# 设置超时时间
ftp = FTP(timeout=30)
# 异常处理示例,出现登录失败等问题时可添加重试逻辑
try:
ftp.login(user, passwd)
except ftplib.error_temp as e:
print(f"登录失败: {e}")
二、实战案例
案例 1:自动备份数据到FTP
import os
from datetime import datetime
from ftplib import FTP
def backup_site(local_dir, ftp_dir):
# 创建带时间戳的备份目录,方便区分不同时间的备份
timestamp = datetime.now().strftime("%Y%m%d_%H%M")
backup_dir = f"{ftp_dir}/backup_{timestamp}"
ftp = FTP('host地址')
ftp.login('user', 'password')
# 在服务器上创建备份目录
ftp.mkd(backup_dir)
ftp.cwd(backup_dir)
# 遍历本地目录,上传所有文件
for file in os.listdir(local_dir):
local_path = os.path.join(local_dir, file)
if os.path.isfile(local_path):
with open(local_path, 'rb') as f:
ftp.storbinary(f'STOR {file}', f)
print(f"备份完成至: {backup_dir}")
ftp.quit()
backup_site('dir1', '/dir2')
案例 2:定时下载日志文件
自动获取服务器日志,便于后续分析和排查问题:
import schedule
import time
from ftplib import FTP
def download_logs():
ftp = FTP('host地址')
ftp.login('user', 'password')
ftp.cwd('/logs')
# 只下载今日日志,精准获取所需数据
today = time.strftime("%Y%m%d")
for file in ftp.nlst():
if today in file:
with open(file, 'wb') as f:
ftp.retrbinary(f'RETR {file}', f.write)
ftp.quit()
# 设置每天凌晨00:05执行下载任务
schedule.every().day.at("00:05").do(download_logs)
while True:
schedule.run_pending()
time.sleep(60)
相关推荐
- python学习教程-第七节内容
-
函数(重点)基本概念Python函数的语法是编程中的核心概念之一,它允许你将代码块封装为可重复调用的单元。基本语法定义函数:示例参数类型位置参数(PositionalArguments)按参数定义...
- Python排序90%人只会用sorted()?这7个高阶技巧让你代码效率翻倍
-
高效处理数据的关键,往往从掌握排序开始。排序操作在Python编程中的重要性常被低估——直到你面对一个杂乱无章的数据集。作为数据处理的核心操作之一,排序效率直接决定了程序性能和代码可读性。无论你正在清...
- 第四章:Python函数
-
4.1函数的定义与调用4.1.1理论知识函数是组织好的、可重复使用的代码块,用于执行特定的任务。它可以提高代码的复用性和可维护性。在Python中,定义函数使用def关键字,其基本语法如下:def...
- ArcGIS 一个独立运行的Python程序编写和打包
-
写代码#coding=utf8#-*-coding:UTF-8-*-importarcpyfromarcpyimportenvimportosimportsys##########...
- python入门到脱坑经典案例—计算三角形的面积
-
下面为大家详细讲解如何用Python计算三角形面积。我们会从最基础的数学公式开始,逐步深入编程实现,并涵盖多个实用版本。以下是完整的教学指南:1.数学原理回顾三角形面积公式:面积=(底边长度...
- Python运算技巧:10种计算列表平方的高效方法
-
1.使用for循环此方法遍历列表中的每个数字,使用**运算符计算其平方,然后将结果添加到新的列表中。2.使用列表推导式此方法使用列表推导式,这是一种更简洁的方式,可以在现有列表的每个项目上执行操作...
- 墙裂推荐,5个学习Python编程最佳的开源库
-
学习Python少不了的就是项目,我在GitHUB上找了几个比较好的开源库,大家可以跟着去学习。1、learn-python3这个存储库一共有19本Jupyter笔记本。它涵盖了字符串和条件之类的基础...
- 使用Python玩转ftplib库:实现ftp文件传输自动化全攻略
-
大家好!在日常工作中都会使用到ftp功能,用于上传和下载文件等,本章主要介绍Python的标准库ftplib来实现FTP文件传输,帮助我们实现ftp自动化。一、ftplib库核心函数速查表1连接与登...
- Python零基础入门学习23:常用第三方库之图像处理库Pillow
-
注:本文所有代码均经过Python3.7实际运行检验,保证其严谨性。本文约2000字,阅读时间约为4分钟。Pillow库的概述Pillow库是Python最好的图像处理库,可能是使用频率最高的图像处...
- Python编程之BeautifulSoup库
-
#头条创作挑战赛#BeautifulSoup是一个可以从HTML或XML文件中快速提取数据的Python库。它能够通过转从入门到精通Python网络爬虫框架Scrapy38换器实...
- Python3 新一代Http请求库Httpx使用(详情版)
-
我们经常使用Python语言的朋友们都清楚,requests是使用率非常高的HTTP库,甚至更早Python2中使用的是urllib、urllib2,也给我们提供了许多方便的功能。但是自从...
- 小白也可以玩的Python爬虫库,收藏一下
-
最近,微软开源了一个项目叫「playwright-python」,作为一个兴起项目,出现后受到了大家热烈的欢迎,那它到底是什么样的存在呢?今天为你介绍一下这个传说中的小白神器。Playwright是...
- apscheduler,一个超厉害的 Python 库!
-
大家好,今天为大家分享一个超厉害的Python库-apscheduler。Github地址:https://github.com/agronholm/apschedulerAPSchedule...
- 给3D Slicer添加Python第三方插件库
-
对临床医生或医学影像算法研究人员来说,3DSlicer是不错的临床实践或科研工具。随着人工智能和深度学习技术的普及,python已经作为原型开发和验证的计算机编程语言。3DSlicer自带pyt...
- Paramiko:一个非常实用的Python库
-
前言Python的Paramiko库,它是一个用于实现SSHv2协议的客户端和服务器的库。通过使用Paramiko,我们可以在Python程序中轻松地实现远程服务器的管理、文件传输等功能。特别做智能硬...
- 一周热门
- 最近发表
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)