基于Python实现ssh兼sftp客户端

 

by:授客 QQ:1033553122

otherTools.py

#!/usr/bin/env/ python
#
-*- coding:utf-8 -*-


__author__
=
'laifuyu'


import

os
import

subprocess

class

OtherTools:
    def

__init__(self):
        self.filepath_list
= []

#
批量创建目录

    def

mkdirs_once_many(self,
path):
        path
= os.path.normpath(path)  #
去掉路径最右侧的 \\
、/

        path
= path.replace('\\',

'/'
)

# 将所有的\\转为/,避免出现转义字符串


        head,
tail = os.path.split(path)
        new_dir_path
=
''  
#
反转后的目录路径

        root
=
''  
#根目录

        if
not

os.path.isdir(path)
and

os.path.isfile(path):  #
如果path指向的是文件,则继续分解文件所在目录

            head,
tail = os.path.split(head)

if

tail ==
''
:
            return

        while

tail:
            new_dir_path
= new_dir_path + tail +
'/'

            head,
tail = os.path.split(head)
            root
= head
        else:
            new_dir_path
= root + new_dir_path

#
批量创建目录

            new_dir_path
= os.path.normpath(new_dir_path)
            head,
tail = os.path.split(new_dir_path)
            temp
=
''

            while

tail:
                temp
= temp +
'/'

+ tail
                dir_path
= root + temp
                if
not

os.path.isdir(dir_path):
                    os.mkdir(dir_path)
                head,
tail = os.path.split(head)


# 测试

ssh_client
= MySSHClient()
ssh_client.connect(hostname='192.168.1.102',

port=22,

username='root',password='huozhe')
ssh_client.exec_command('ls
-l'
)

ssh_client.download_file('/root/dirForDownload/file',

'./test1.txt'
)
ssh_client.download_file('/root/dirForDownload/file',

'.
\test2.txt')
ssh_client.download_file('/root/dirForDownload/file',

'd:
\\test3.txt')
ssh_client.download_file('/root/dirForDownload/file',

'd:
\test4.txt')
ssh_client.download_file('/root/dirForDownload/file',

'd:\mytest4.txt'
)
ssh_client.download_file('/root/dirForDownload/file',

'd:/test5.txt'
)
ssh_client.download_file('/root/dirForDownload/file',

'd:\dir1\dir2
\test6.txt')

ssh_client.upload_file('./test1.txt','/root/test1.txt'

)
ssh_client.upload_file('d:\mytest4.txt','/root/mytestfile.txt'

)
ssh_client.upload_file('d:\dir1\dir2\test6.txt','./test6.txt'

)
ssh_client.close()

运行结果:

注意事项

# 1. 下载文件
#
1) 不支持目录级的下载,即只能下载指定的单个非目录文件
#
2) 本地目标文件路径只支持文件路径,不支持目录(比如 localpath='d:\\'),目标文件所在的上级路径可以不存在(但路径必须位于分区下)
#
比如欲下载到本地路径:d:\dir1\dir2\test.txt, d:\dir1\dir2\可以不存在
#
3) 本地目标文件支持相对路径,比如./text.txt,远程目标文件仅支持绝对路径

#
2. 上传文件
#
1) 不支持目录级的上传,只能上传指定的单个文件
#
2) 远程目标文件所在的上级路径必须存在,比如remotepath='/root/dir1/tarfile' ,其中/root/dir1必须存在
#
3) 远程目标文件、本地文件路径都支持相对路径,比如./text.txt

#
3. 重复下载文件、上传文件,会自动覆盖已经下载的文件、已上传的文件

参考文档:

http://docs.paramiko.org/en/2.4/api/channel.html

http://docs.paramiko.org/en/2.4/api/sftp.html#paramiko.sftp_client.SFTPClient

Python 基于Python实现的ssh兼sftp客户端(下)的更多相关文章

  1. Python 基于Python实现的ssh兼sftp客户端(上)

    基于Python实现的ssh兼sftp客户端   by:授客 QQ:1033553122 实现功能 实现ssh客户端兼ftp客户端:实现远程连接,执行linux命令,上传下载文件 测试环境 Win7 ...

  2. Python 基于Python及zookeeper实现简单分布式任务调度系统设计思路及核心代码实现

    基于Python及zookeeper实现简单分布式任务调度系统设计思路及核心代码实现   by:授客 QQ:1033553122 测试环境 功能需求 实现思路 代码实践(关键技术点实现) 代码模块组织 ...

  3. Python 基于python操纵zookeeper介绍

    基于python操纵zookeeper介绍 by:授客  QQ:1033553122 测试环境 Win7 64位 Python 3.3.4 kazoo-2.6.1-py2.py3-none-any.w ...

  4. Python 基于Python结合pykafka实现kafka生产及消费速率&主题分区偏移实时监控

    基于Python结合pykafka实现kafka生产及消费速率&主题分区偏移实时监控   By: 授客 QQ:1033553122   1.测试环境 python 3.4 zookeeper- ...

  5. Python 基于Python从mysql表读取千万数据实践

    基于Python 从mysql表读取千万数据实践   by:授客 QQ:1033553122 场景:   有以下两个表,两者都有一个表字段,名为waybill_no,我们需要从tl_waybill_b ...

  6. Python基于Python实现批量上传文件或目录到不同的Linux服务器

    基于Python实现批量上传文件或目录到不同的Linux服务器   by:授客 QQ:1033553122 实现功能 1 测试环境 1 使用方法 1 1. 编辑配置文件conf/rootpath_fo ...

  7. Python 基于python编写一些算法程序等

    基于python编写一些算法程序等 by:授客 QQ:1033553122 QQ群:7156436 没特意去研究,只是这对群友在QQ群里(7156436)提出的一些小程序实现.编程题,算法.问题等,本 ...

  8. Python 基于python+mysql浅谈redis缓存设计与数据库关联数据处理

    基于python+mysql浅谈redis缓存设计与数据库关联数据处理 by:授客  QQ:1033553122 测试环境 redis-3.0.7 CentOS 6.5-x86_64 python 3 ...

  9. Python 基于python操纵redis入门介绍

    基于python操纵redis入门介绍 by:授客  QQ:1033553122 测试环境 redis-3.0.7 CentOS 6.5-x86_64 python 3.3.2 基于Python操作R ...

随机推荐

  1. 性能瓶颈之System

    如果Source,Target,Mapping和Session都不存在性能上的瓶颈,则问题可能会出在System 因为Integration Service运行时,它使用了System的资源去运行组件 ...

  2. 解决 .NET Core 在 Linux 下的时区问题

    环境 # dotnet --info .NET Core SDK (reflecting any global.json): Version: Commit: 8a7ff6789d Runtime E ...

  3. Elasticsearch基本概念及核心配置文件详解

    Elasticsearch5.X,下列的是Elasticsearch2.X系类配置,其实很多配置都是相互兼容的 1. 配置文件 config/elasticsearch.yml 主配置文件 confi ...

  4. Core2.0知识整理

    概述 Commond-Line ASP.NET结构文件 Startup 配置文件 中间件和依赖注入 依赖注入原理 框架自带的依赖注入(IServiceCollection) 依赖注入生命周期 依赖注入 ...

  5. mysql 更新语句中加判断条件

    UPDATE loan_overdue_list l setl.type_status=(CASE WHEN l.overdue_days>(select c.overdue_one from ...

  6. 一次Linux自动化部署尝试

    最近做一个项目临近测试,购买的是阿里云的服务器,每次部署都是手动打包war,然后上传到服务器,然后修改配置文件,不仅繁琐,而且费时,就思索着找一个一键式的部署方式,今天终于腾出时间来做这件事,记录一下 ...

  7. Apache Flink 漫谈系列 - JOIN 算子

    聊什么 在<Apache Flink 漫谈系列 - SQL概览>中我们介绍了JOIN算子的语义和基本的使用方式,介绍过程中大家发现Apache Flink在语法语义上是遵循ANSI-SQL ...

  8. 如何像Python高手(Pythonista)一样编程

    最近在网上看到一篇介绍Pythonic编程的文章:Code Like a Pythonista: Idiomatic Python,其实作者在2006的PyCon会议后就写了这篇文章,写这篇文章的主要 ...

  9. JS脚本获取URL参数并调用

    首先增加一个脚本库,可以是Zepto或者jQuery的,然后获取之后使用switch进行分流处理 <script type="text/javascript" src=&qu ...

  10. 爬虫应对js混淆的方法

    大家做爬虫可能经常要跟js打交道.如果积累一定的经验肯定会遇到eval(....);这种js,很多新人可能慌了,woc这怎么办??????? 下面楼主给大家介绍一种方法简单,有效. F12 在Cons ...