- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章详解Python下ftp上传文件linux服务器由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
模块介绍:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
from
ftplib
import
FTP
ftp
=
FTP()
#设置变量
ftp.set_debuglevel(
2
)
#打开调试级别2 显示详细信息
ftp.connect(
"IP"
,
"port"
)
#连接ftp, IP和端口
ftp.log(
"user"
,
"password"
)
#连接的用户名、密码
ftp.cwd(pathname)
#设置FTP当前操作的路径
ftp.
dir
()
#显示目录下的文件信息
ftp.nlst()
#获取目录下的文件
ftp.mkd(pathname)
#新建远程目录
ftp.pwd()
#返回当前所在位置
ftp.rmd(dirname)
#删除远程目录
ftp.delete(filename)
#删除远程文件
ftp.rename(from_name, to_name)
#修改文件名
ftp.storbinaly(
"STOR filename.txt"
, file_handel, bufsize)
# 上传目标文件
ftp.retrbinaly(
"RETR filename.txt"
, file_handel, bufsize)
# 上传FTP文件
|
功能实现:
ftp.dir() 能显示目录下的文件信息,考虑到要分别对文件夹个数和文件数目进行统计,文件夹下存在文件夹和文件嵌套;将dir()后的目录信息放入列表,对列表进行操作;进入子文件夹后进行递归调用操作.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
# -*- coding: utf-8 -*-
from
ftplib
import
FTP
ftp
=
FTP()
ftp.connect(
'132.121.xx.xxx'
,
'xx909'
)
ftp.login(
'crmyun_xxx'
,
'wyjjjjxJ'
)
sum1
=
0
sum2
=
0
value
=
0
def
search_file(start_dir):
ftp.cwd(start_dir)
print
ftp.pwd()
dir_res
=
[]
ftp.
dir
(
'.'
, dir_res.append)
#对当前目录进行dir(),将结果放入列表
for
i
in
dir_res:
if
i.startswith(
"d"
):
global
sum1
sum1
+
=
1
search_file(ftp.pwd()
+
"/"
+
i.split(
" "
)[
-
1
])
ftp.cwd(
'..'
)
else
:
global
sum2, value
sum2
+
=
1
val
=
i.split(
" "
)[
-
1
]
value
+
=
ftp.size(val)
if
ftp.pwd().endswith(
'/'
):
# print ftp.pwd()+val+" "+str(ftp.size(val))+" B" #打印出每个文件路径和大小
pass
else
:
# print ftp.pwd()+"/"+val+" "+str(ftp.size(val))+" B"
pass
def
sum_file(file_path):
search_file(file_path)
print
"folder number is "
+
str
(sum1)
+
", file number is "
+
str
(sum2)
+
", Totle size is "
+
str
(value)
+
" B"
if
__name__
=
=
'__main__'
:
sum_file(
"/apps/crmyun/crmyun_755"
)
|
展示结果:
完整上传程序 。
Python中默认安装的ftplib模块定义了FTP类,其中函数有限,可用来实现简单的ftp客户端,用于上传或下载文件,函数列举如下 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
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.quit()与FTP.close()的区别 。
FTP.quit():发送QUIT命令给服务器并关闭掉连接。这是一个比较“缓和”的关闭连接方式,但是如果服务器对QUIT命令返回错误时,会抛出异常.
FTP.close():单方面的关闭掉连接,不应该用在已经关闭的连接之后,例如不应用在FTP.quit()之后.
例:下载、上传文件 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
# coding: utf-8
from
ftplib
import
FTP
import
time
import
tarfile
import
os
# !/usr/bin/python
# -*- coding: utf-8 -*-
from
ftplib
import
FTP
def
ftpconnect(host, username, password):
ftp
=
FTP()
# ftp.set_debuglevel(2)
ftp.connect(host,
21
)
ftp.login(username, password)
return
ftp
#从ftp下载文件
def
downloadfile(ftp, remotepath, localpath):
bufsize
=
1024
fp
=
open
(localpath,
'wb'
)
ftp.retrbinary(
'RETR '
+
remotepath, fp.write, bufsize)
ftp.set_debuglevel(
0
)
fp.close()
#从本地上传文件到ftp
def
uploadfile(ftp, remotepath, localpath):
bufsize
=
1024
fp
=
open
(localpath,
'rb'
)
ftp.storbinary(
'STOR '
+
remotepath, fp, bufsize)
ftp.set_debuglevel(
0
)
fp.close()
if
__name__
=
=
"__main__"
:
ftp
=
ftpconnect(
"113.105.139.xxx"
,
"ftp***"
,
"Guest***"
)
downloadfile(ftp,
"Faint.mp4"
,
"C:/Users/Administrator/Desktop/test.mp4"
)
#调用本地播放器播放下载的视频
os.system(
'start "C:\Program Files\Windows Media Player\wmplayer.exe" "C:/Users/Administrator/Desktop/test.mp4"'
)
uploadfile(ftp,
"C:/Users/Administrator/Desktop/test.mp4"
,
"test.mp4"
)
ftp.quit()
|
原文链接:https://blog.csdn.net/Gzigithub/article/details/80729509 。
最后此篇关于详解Python下ftp上传文件linux服务器的文章就讲到这里了,如果你想了解更多关于详解Python下ftp上传文件linux服务器的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
谁能解释一下 Server.MapPath(".")、Server.MapPath("~")、Server.MapPath(@"之间的区别\") 和 Server.MapPath("/")? 最佳答案
我不知道,为什么我们要使用 Server.UrlEncode() & Server.UrlDecode()?!在 QueryString 中我们看到 URL 中的任何内容,那么为什么我们要对它们进行编
我已经通过 WHM 在我的一个域上安装了 ssl 证书。网站正在使用 https://xyz.com . 但是它不适用于 https://www.xyz.com .我已经检查了证书,它也适用于 www
我已经使用 WMI 检测操作系统上是否存在防病毒软件,itz 正常工作并通过使用命名空间向我显示防病毒信息,例如 win xp 和 window7 上的名称和实例 ID:\root\SecurityC
我们有 hive 0.10 版本,我们想知道是否应该使用 Hive Server 1 或 Hive Server2。另一个问题是连接到在端口 10000 上运行的 Hive 服务器,使用 3rd 方工
我想在 C++ 中使用 Windows Server API 设置一个 HTTPS 服务器,我使用了示例代码,它在 HTTP 上工作正常,但我就是不能让它在 HTTPS 上工作。 (我不想要客户端 S
我写了一个非常基本的类来发送电子邮件。我用 smtp 服务器对其进行了测试,它工作正常,但是当我尝试使用我公司的交换服务器时,它给出了这个异常: SMTP 服务器需要安全连接或客户端未通过身份验证。服
我的应用程序包含一个“网关”DataSnap REST 服务器,它是所有客户端的第一个访问点。根据客户端在请求中传递的用户名(基本身份验证),请求需要重定向到另一个 DataSnap 服务器。我的问题
我有一个 Tomcat 服务器和一个 Glassfish4 服务器。我的 Servlet 在 Tomcat 服务器上启动得很好,但在 Glassfish4 服务器上给我一个“HTTP Status 4
我在 vmware 上创建了一个 ubuntu 服务器。我用它作为文件服务器。如果我通过托管虚拟机的计算机进行连接,则可以访问它。我无法从同一网络上的其他计算机执行此操作。提前致谢! 最佳答案 首先确
如何重启 Rails 服务器?我从 开始 rails server -d 所以服务器是分离的 我知道的唯一方法就是去做ps 辅助 | grep rails 并 kill -9关于过程#但是像这样杀死进
我实际上正在尝试找到编写一个简单的 XMPP 服务器的最佳方法,或者找到一个占用空间非常小的服务器。我只关心XMPP的核心功能(状态、消息传递、群组消息传递)。目前还在学习 XMPP 协议(proto
我实际上正在尝试找到编写简单 XMPP 服务器的最佳方法,或者找到一个占用空间非常小的方法。我只关心 XMPP 的核心功能(统计、消息、组消息)。目前也在学习 XMPP 协议(protocol),所以
我们正在尝试从 Java JAX-RS 适配器访问 SOAP 1.1 Web 服务。 我们正在使用从 WSDL 生成的 SOAP 客户端。 但是当解码 SOAP 故障时,我们得到以下异常: ... C
目前,我和许多其他人正在多个平台(Windows、OS X 和可能的 Linux)上使用 Python HTTP 服务器。我们正在使用 Python HTTP 服务器来测试 JavaScript 游戏
我有一个连续运行的服务器程序(C#/.NET 2.0 on Linux with mono),我想从 PHP 脚本连接到它以在网站上显示状态信息。 目的是创建一个(某种)实时浏览器游戏(无 Flash
所以我有一个单页客户端应用程序。 正常流程: 应用程序 -> OAuth2 服务器 -> 应用程序 我们有自己的 OAuth2 服务器,因此人们可以登录应用程序并获取与用户实体关联的 access_t
我们刚刚将测试 Web 服务器从 Server 2008 升级到 Server 2012 R2。我们有一个部署我们网站的批处理脚本。当它将站点推送到服务器时,它现在失败了。奇怪的是,我可以使用相同的发
建议一些加载SpagoBI服务器的方法,我尝试了所有方法来解析spagobi服务器。在 Catalina 中,错误是 - * SEVERE: Unable to process Jar entry [
当我们点击应用程序服务器(apache tomcat)时,它会创建一个线程来处理我们的请求并与 tomcat 连接,建立连接,tomcat 创建另一个线程来处理请求并将其传递给连接,连接线程将其传递给
我是一名优秀的程序员,十分优秀!