1 paramiko (基于openssh,python封装的ssh)
模块python自带
用法:
import paramiko
ssh = paramiko.SSHClient()
ssh.load_system_host_keys()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(hostname='192.168.100.20',port=58422,username='oldboy')
stdin, stdout,stderr=ssh.exec_command('uptime')
type(stdout)
paramiko.ChannelFile
print stderr.readlines()
[]
print stdout.readlines()
[' 21:35:05 up 1 day, 55 min, 2 users, load average: 0.00, 0.00, 0.00\n']
相当于shell当中的
ssh -p58422 [email protected] -o StrictHostKeyChecking=no 'uptime'
2 subprocess(尽量不要用这个模块,返回不美观,如果只是执行shell命令推荐commands模块) Python3
python自带模块 使用在python 3中取代python 2 中的commands模块
参考:http://www.jb51.net/article/48086.htm
常用fork子进程执行shell命令,可以返回结果和返回值
举例:
只需要返回值
In [6]: retcode = subprocess.call('ls -l', shell=True)
total 12
-rw-rw-r--. 1 oldboy oldboy 239 Jan 19 21:13 access.log
-rw-rw-r--. 1 oldboy oldboy 458 Jan 19 20:50 arp.txt
-rw-r--r--. 1 oldboy oldboy 184 Jan 16 12:04 hosts
In [7]: print retcode
0
注意:
shell默认为False,等于 retcode = subprocess.call(["ls", "-l"]) 列表的形式第一个为命令,后面的都作为参数传递
需要返回值
child1 = subprocess.Popen(["cat","/etc/passwd"], stdout=subprocess.PIPE)
child1.stdout.readlines()
常用:
file="get_ldap_zhname.sh"
child1 = subprocess.Popen('sh ' + file + ' '+ um, shell=True, stdout=subprocess.PIPE)
status = child1.wait()
output = child1.stdout.read().strip()
3 comands模块(python 2中)
python自带模块
status,output = commands.getstatusoutput('cat /etc/passwd')
优点: 无论命令执行错误与正确,正确输出和错误输出都以字符串原样的字符串形式传递给output
4 multiprocessing模块
python自带模块
pool = multiprocessing.Pool(processes=4)
result_tmp.append(pool.apply_async(func, ( arg1,arg2,arg3)))
5 ping模块
pip install ping
result = ping.quiet_ping(addr, timeout=2, count=5, psize=64)
loss_rate=result[0]
max_time=result[1]
average_time=result[2]
常用处理(取float的位数和把None值 变为0表示不通):
loss_rate = result[0]
max_time = float('%.3f'% result[1]) if isinstance(result[1], float) else 0
#if max_time and average_time is None use 0
average_time = float('%.3f'% result[2]) if isinstance(result[2], float) else 0
6 random模块
python自带
import random
常用函数
a. random函数 生成一个0-1的随机数
In [26]: random.random()
Out[26]: 0.6289910862564466
b. sample 在一个列表(字符串)中随机抽样N个数,返回一个新的列表
In [27]: random.sample(xrange(1,100), 3)
Out[27]: [94, 91, 53]
In [28]: random.sample('asdfasdf', 3)
Out[28]: ['f', 'a', 'a']
c. randint 函数,在指定的整数范围内(1<=x<=20),返回一个数
In [29]: random.randint(1,20)
Out[29]: 18
7 uuid模块
python自带
import uuid
常用: uuid1函数,通过mac和时间戳生成全球唯一的id
In [49]: uuid.uuid1()
Out[49]: UUID('cbb8c051-0929-11e6-9ba3-8c2937eebf3a')
(注意是 UUID类型,经常转化为str类型)
In [50]: str(uuid.uuid1())
Out[50]: 'cf296582-0929-11e6-8bbf-8c2937eebf3a'
8 hashlib 模块
常用md5函数 (常结合uuid来生成一个32位的随机数)
In [48]: hashlib.md5(str(uuid.uuid1())).hexdigest()
Out[48]: 'd4aacc5bb29a24fd9db8e2ea1bf53cb7'
9 时间模块 time, datetime timedelta
参考: http://cuidehua.blog.51cto.com/5449828/1767046
10 json模块
参考: http://cuidehua.blog.51cto.com/5449828/1767061
11 re 正则表达式模块
python自带
常用 判断一个字符串是否符合指定的表达式
In [9]: import re
In [10]: s = "10.1.1.223"
In [11]: if re.match(r"10.1", s):
....: print "为10.1网段"
....: else:
....: print "不在10.1网段"
....:
为10.1网段
区别re.match() 和re.search()的区别
re.match(r“10.2,s”) 和 re.search(r”^10.2”,s) 是一样的
注:
1 匹配则返回对象本身,不匹配则放回None
2 match只匹配字符串的开始,如果开始不符合正则表达式,就返回None,而search匹配整个字符串,匹配到了则算匹配成功
12 collections 模块OrderedDict 函数
python自带内模块
作用: 定义有序字典,当有需要dict字典的key是有序的
In [73]: from collections import OrderedDict
In [74]: od = OrderedDict()
In [75]: od['key1'] = 'value1'
In [76]: od['key2'] = 'value2'
In [77]: od['key3'] = 'value3'
In [78]: od
Out[78]: OrderedDict([('key1', 'value1'), ('key2', 'value2'), ('key3', 'value3')])
In [79]: od.keys()
Out[79]: ['key1', 'key2', 'key3']
In [80]: for k,v in od.ite
od.items od.iteritems od.iterkeys od.itervalues
In [80]: for k,v in od.items():
....: print k,v
....:
key1 value1
key2 value2
key3 value3
12 collections 模块Counter 函数
python再带内建(python 2.7 以上版本才有Counter函数)
Counter函数是属于字典的子类,所有也拥有字典相关的特性
重要用途: 返回列表(字符串)中元素出现的次数
In [11]: from collections import Counter
In [12]: l = ['a','b','a','c','a','d']
In [13]: number_rep= Counter(l)
返回的是keys和次数组成的字典
In [14]: number_rep
Out[14]: Counter({'a': 3, 'b': 1, 'c': 1, 'd': 1})
In [15]: type(number_rep)
Out[15]: collections.Counter
拥有字典的大部分属性函数
In [16]: number_rep["a"]
Out[16]: 3
In [18]: number_rep.keys()
Out[18]: ['a', 'c', 'b', 'd']
返回出现最多的key和次数组成的二元元组列表
In [19]: number_rep.most_common(1)
Out[19]: [('a', 3)]
也有相加功能
In [21]: s = "efghfgfefda"
In [22]: Counter(s)
Out[22]: Counter({'a': 1, 'd': 1, 'e': 2, 'f': 4, 'g': 2, 'h': 1})
In [23]: number_rep + Counter(s)
Out[23]: Counter({'a': 4, 'b': 1, 'c': 1, 'd': 2, 'e': 2, 'f': 4, 'g': 2, 'h': 1})
注意:python 2.6环境中
pip install counter
from counter import Counter
13 linecache模块
python自带
import linecache
作用,读取文本行,大的文本,可以缓存到内存,下次再次读取直接从内存中拿取
用法:
返回所有行,以列表的形式
l_lines = linecache.getlines('filename')
返回指定的一行,返回字符串形式
s_line = linecache.getline('filename', linenumber).rstrip()
更新缓存,是直接从磁盘中读取文件,并更新内存中的缓存,返回列表形式的所有行
l_lines = linecache.updatecache('filename')
更新缓存 所有拥有缓存的
linecache.checkcache()
或者 指定更新的文件
linecache.checkcache('filename')