模块分为三种:

内置模块

开源模块

自定义模块

一:自定义模块

1.定义模块:即编写具有某一功能的python文件ftp.py,ftp既模块名

ftp.py

def get(file_path):    print('download file %s' %file_path)    def put(file_path):    print('download file %s' %file_path)

2.模块导入方式

import ftp

from ftp import get

from ftp import put as upload

from ftp import *

3.名称空间

4.import的本质

导入一个模块本质就是解释执行一个python文件

导入一个包本质就是解释该包下的__init__.py文件

5.搜索路径与sys.path操作

二:开源模块

1.定义模块:下载安装

方式一:

yum pipapt-get...

方式二:

下载源码解压源码进入目录编译源码    python setup.py build安装源码    python setup.py install

注:在使用源码安装时,需要使用到gcc编译和python开发环境,所以,需要先执行:

yum install gccyum install python-devel或apt-get python-dev

安装成功后,模块会自动安装到 sys.path 中的某个目录中,如:

/usr/lib/python2.7/site-packages/

2.导入模块(同自定义模块方式)

3:paramiko

i:下载安装

# pycrypto,由于 paramiko 模块内部依赖pycrypto,所以先下载安装pycrypto # 下载安装 pycryptowget http://files.cnblogs.com/files/wupeiqi/pycrypto-2.6.1.tar.gztar -xvf pycrypto-2.6.1.tar.gzcd pycrypto-2.6.1python setup.py buildpython setup.py install # 进入python环境,导入Crypto检查是否安装成功 # 下载安装 paramikowget http://files.cnblogs.com/files/wupeiqi/paramiko-1.10.1.tar.gztar -xvf paramiko-1.10.1.tar.gzcd paramiko-1.10.1python setup.py buildpython setup.py install # 进入python环境,导入paramiko检查是否安装成功

ii.使用模块

1. 基于用户名和密码的 sshclient 方式登录

import paramiko# 建立一个sshclient对象ssh = paramiko.SSHClient()# 允许将信任的主机自动加入到host_allow 列表,此方法必须放在connect方法的前面ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())# 调用connect方法连接服务器ssh.connect(hostname='172.16.209.19',port=22,username='root',password='123')# 执行命令stdin, stdout, stderr = ssh.exec_command('df -hl')# 结果放到stdout中,如果有错误将放到stderr中print(stdout.read().decode())# 关闭连接ssh.close()

注意:以sshclient方式运行交互式命令需要增加两行

import paramiko# 建立一个sshclient对象ssh = paramiko.SSHClient()# 允许将信任的主机自动加入到host_allow 列表,此方法必须放在connect方法的前面ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())# 调用connect方法连接服务器ssh.connect(hostname='172.16.209.119',port=22,username='root',password='123')# 执行命令stdin, stdout, stderr = ssh.exec_command("passwd lhf")# 结果放到stdout中,如果有错误将放到stderr中stdin.write('123\n')stdin.flush()stdin.write('123\n')stdin.flush()print(stderr.read())# 关闭连接ssh.close()

2 基于用户名和密码的 transport 方式登录 

其实paramiko.SSHClient().connect()这个方法的内部实现调用的就是Transport().connect()这个方法。所以可以认为Transport()是paramiko里面创建连接的通用方法。

#!/usr/bin/pythonimport paramiko# 实例化一个transport对象trans = paramiko.Transport(('172.16.209.119', 22))# 建立连接trans.connect(username='root', password='123')# 将sshclient的对象的transport指定为以上的transssh = paramiko.SSHClient()ssh._transport = trans# 执行命令,和传统方法一样stdin, stdout, stderr = ssh.exec_command('df -hl')print(stdout.read().decode())# 关闭连接trans.close()

3.基于公钥密钥的 SSHClient 方式登录

#!/usr/bin/pythonimport paramiko# 指定本地的RSA私钥文件,如果建立密钥对时设置的有密码,password为设定的密码,如无不用指定password参数pkey = paramiko.RSAKey.from_private_key_file('D:\id_rsa',password='123456')# 建立连接ssh = paramiko.SSHClient()ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())ssh.connect(hostname='172.16.209.119',            port=22,            username='root',            pkey=pkey)# 执行命令stdin, stdout, stderr = ssh.exec_command('df -hl')# 结果放到stdout中,如果有错误将放到stderr中print(stdout.read().decode())# 关闭连接ssh.close()

4 .基于密钥的 Transport 方式登录

#!/usr/bin/pythonimport paramiko# 指定本地的RSA私钥文件,如果建立密钥对时设置的有密码,password为设定的密码,如无不用指定password参数pkey = paramiko.RSAKey.from_private_key_file('D:\id_rsa', password='123456')# 建立连接trans = paramiko.Transport(('172.16.209.119', 22))trans.connect(username='root', pkey=pkey)# 将sshclient的对象的transport指定为以上的transssh = paramiko.SSHClient()ssh._transport = trans# 执行命令,和传统方法一样stdin, stdout, stderr = ssh.exec_command('df -hl')print(stdout.read().decode())# 关闭连接trans.close()

传文件 SFTP

#!/usr/bin/pythonimport paramiko# 实例化一个trans对象# 实例化一个transport对象trans = paramiko.Transport(('172.16.209.119', 22))# 建立连接trans.connect(username='root', password='123')# 实例化一个 sftp对象,指定连接的通道sftp = paramiko.SFTPClient.from_transport(trans)# 发送文件sftp.put(localpath='D:\id_rsa', remotepath='/tmp/id_rsa')# 下载文件# sftp.get(remotepath, localpath)trans.close()

三:内置模块

  1. os模块

用于提供系统级别的操作

os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径os.chdir("dirname")  改变当前脚本工作目录;相当于shell下cdos.curdir  返回当前目录: ('.')os.pardir  获取当前目录的父目录字符串名:('..')os.makedirs('dirname1/dirname2')    可生成多层递归目录os.removedirs('dirname1')    若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推os.mkdir('dirname')    生成单级目录;相当于shell中mkdir dirnameos.rmdir('dirname')    删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirnameos.listdir('dirname')    列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印os.remove()  删除一个文件os.rename("oldname","newname")  重命名文件/目录os.stat('path/filename')  获取文件/目录信息os.sep    输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/"os.linesep    输出当前平台使用的行终止符,win下为"\t\n",Linux下为"\n"os.pathsep    输出用于分割文件路径的字符串os.name    输出字符串指示当前使用平台。win->'nt'; Linux->'posix'os.system("bash command")  运行shell命令,直接显示os.environ  获取系统环境变量os.path.abspath(path)  返回path规范化的绝对路径os.path.split(path)  将path分割成目录和文件名二元组返回,它仅仅是以 "PATH" 中最后一个 '/' 作为分隔符,分隔后,将索引为0的视为目录(路径),将索引为1的视为文件名os.path.dirname(path)  返回path的目录。其实就是os.path.split(path)的第一个元素os.path.basename(path)  返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素os.path.exists(path)  如果path存在,返回True;如果path不存在,返回Falseos.path.isabs(path)  如果path是绝对路径,返回Trueos.path.isfile(path)  如果path是一个存在的文件,返回True。否则返回Falseos.path.isdir(path)  如果path是一个存在的目录,则返回True。否则返回Falseos.path.join(path1[, path2[, ...]])  将多个路径组合后返回,第一个绝对路径之前的参数将被忽略os.path.getatime(path)  返回path所指向的文件或者目录的最后存取时间os.path.getmtime(path)  返回path所指向的文件或者目录的最后修改时间

os.path.join示范

>>> os.path.join('c:\\', 'csv', 'test.csv') 'c:\\csv\\test.csv' >>> os.path.join('windows\temp', 'c:\\', 'csv', 'test.csv') 'c:\\csv\\test.csv' >>> os.path.join('/home/aa','/home/aa/bb','/home/aa/bb/c') '/home/aa/bb/c'