python模块-part2

2020-01-08 10:51:38 浏览数 (1)

模块分为三种:

内置模块

开源模块

自定义模块

一:自定义模块

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

ftp.py

代码语言:javascript复制
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.定义模块:下载安装

方式一:

代码语言:javascript复制
yum 
pip
apt-get
...

方式二:

代码语言:javascript复制
下载源码
解压源码
进入目录
编译源码    python setup.py build
安装源码    python setup.py install

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

代码语言:javascript复制
yum install gcc
yum install python-devel
或
apt-get python-dev

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

代码语言:javascript复制
/usr/lib/python2.7/site-packages/

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

3:paramiko

i:下载安装

代码语言:javascript复制
# pycrypto,由于 paramiko 模块内部依赖pycrypto,所以先下载安装pycrypto
 
# 下载安装 pycrypto
wget http://files.cnblogs.com/files/wupeiqi/pycrypto-2.6.1.tar.gz
tar -xvf pycrypto-2.6.1.tar.gz
cd pycrypto-2.6.1
python setup.py build
python setup.py install
 
# 进入python环境,导入Crypto检查是否安装成功
 
# 下载安装 paramiko
wget http://files.cnblogs.com/files/wupeiqi/paramiko-1.10.1.tar.gz
tar -xvf paramiko-1.10.1.tar.gz
cd paramiko-1.10.1
python setup.py build
python setup.py install
 
# 进入python环境,导入paramiko检查是否安装成功

ii.使用模块

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

代码语言:javascript复制
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方式运行交互式命令需要增加两行

代码语言:javascript复制
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('123n')
stdin.flush()
stdin.write('123n')
stdin.flush()
print(stderr.read())
# 关闭连接
ssh.close()

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

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

代码语言:javascript复制
#!/usr/bin/python
import paramiko

# 实例化一个transport对象
trans = paramiko.Transport(('172.16.209.119', 22))
# 建立连接
trans.connect(username='root', password='123')

# 将sshclient的对象的transport指定为以上的trans
ssh = paramiko.SSHClient()
ssh._transport = trans
# 执行命令,和传统方法一样
stdin, stdout, stderr = ssh.exec_command('df -hl')
print(stdout.read().decode())

# 关闭连接
trans.close()

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

代码语言:javascript复制
#!/usr/bin/python
import 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 方式登录

代码语言:javascript复制
#!/usr/bin/python
import 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指定为以上的trans
ssh = paramiko.SSHClient()
ssh._transport = trans

# 执行命令,和传统方法一样
stdin, stdout, stderr = ssh.exec_command('df -hl')
print(stdout.read().decode())

# 关闭连接
trans.close()

传文件 SFTP

代码语言:javascript复制
#!/usr/bin/python
import 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模块

用于提供系统级别的操作

代码语言:javascript复制
os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径
os.chdir("dirname")  改变当前脚本工作目录;相当于shell下cd
os.curdir  返回当前目录: ('.')
os.pardir  获取当前目录的父目录字符串名:('..')
os.makedirs('dirname1/dirname2')    可生成多层递归目录
os.removedirs('dirname1')    若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推
os.mkdir('dirname')    生成单级目录;相当于shell中mkdir dirname
os.rmdir('dirname')    删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname
os.listdir('dirname')    列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印
os.remove()  删除一个文件
os.rename("oldname","newname")  重命名文件/目录
os.stat('path/filename')  获取文件/目录信息
os.sep    输出操作系统特定的路径分隔符,win下为"\",Linux下为"/"os.linesep    输出当前平台使用的行终止符,win下为"tn",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不存在,返回False
os.path.isabs(path)  如果path是绝对路径,返回True
os.path.isfile(path)  如果path是一个存在的文件,返回True。否则返回False
os.path.isdir(path)  如果path是一个存在的目录,则返回True。否则返回False
os.path.join(path1[, path2[, ...]])  将多个路径组合后返回,第一个绝对路径之前的参数将被忽略
os.path.getatime(path)  返回path所指向的文件或者目录的最后存取时间
os.path.getmtime(path)  返回path所指向的文件或者目录的最后修改时间

os.path.join示范

代码语言:javascript复制
>>> os.path.join('c:\', 'csv', 'test.csv') 
'c:\csv\test.csv' 
>>> os.path.join('windowstemp', 'c:\', 'csv', 'test.csv') 
'c:\csv\test.csv' 
>>> os.path.join('/home/aa','/home/aa/bb','/home/aa/bb/c') 
'/home/aa/bb/c'

0 人点赞