【Python自动化运维之路Day6】
1、递归思考题,阶乘
使用递归方式(函数)计算: 1*2*3*4*5*6*7*8*9*10的值
def func(num): if num==1: return 1 return num*func(num-1)
2、反射
利用字符串的形式去(模块)中去操作(寻找,检查,删除、增加)
hasattr(obj,attr) 检查成员是否存在,返回一个布尔值,存在为True,否则为False
getattr(obj,attr) 获取属性obj的值attr, 如 attr为login,则返回obj.login
setattr(obj,attr,val) 调用这个方法给obj名为attr的值的属性赋值为val,如 setattr(user_manager,'edit_pass',True)
delattr(obj,attr) 删除obj中的属性为attr的值,如attr等于login,则删除obj.login
def run(): # account/login inp = input('请输入要访问的url:') m, f = inp.split('/') # import lib.account obj = __import__("lib."+ m, fromlist=True) if hasattr(obj, f): func = getattr(obj, f) func() else: print('404')
PS; __import__ 以字符串形式导入模块,lib.account 默认只导入lib。导入路径需要参数fromlist=True
3、补充几个全局变量
__doc__ 默认的帮助信息,定义的时候在文件首部用三个引号引起来定义 __file__ import sys sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__)))) __package__ 返回当前模块所属 __name__ 特殊变量,只有执行当前文件时,当前文件的__name__值才等于__main__. vars() 查看提供的变量
4、模块
1) os模块
os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径 os.chdir("dirname") 改变当前脚本工作目录;相当于shell下cd os.curdir 返回当前目录: ('.') os.pardir 获取当前目录的父目录字符串名:('..') os.makedirs('dir1/dir2') 可生成多层递归目录 os.removedirs('dirname1') 若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推 os.mkdir('dirname') 生成单级目录;相当于shell中mkdir dirname os.rmdir('dirname') 删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname os.listdir('dirname') 列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印 os.remove() 删除一个文件 os.rename("oldname","new") 重命名文件/目录 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分割成目录和文件名二元组返回 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所指向的文件或者目录的最后修改时间
2) sys模块
Python运行时和解释器相关的部分
sys.argv 命令行参数List,第一个元素是程序本身路径 sys.exit(n) 退出程序,正常退出时exit(0) sys.version 获取Python解释程序的版本信息 sys.maxint 最大的Int值 sys.path 返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值 sys.platform 返回操作系统平台名称 sys.stdin 输入相关 sys.stdout 输出相关 sys.stderror 错误相关
进度条实例:
#!/usr/bin/env python3 # -*- coding: utf-8 -*- import sys,time def f1(num,total): rate = float(num) / float(total) rate_num = int(rate * 100) result = '\r{}>{:>}%'.format('#'*num,rate_num) sys.stdout.write(result) if __name__ == '__main__': for i in range(0,100): time.sleep(0.1) f1(i,100)
3) hashlib模块
用于加密相关的操作,代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,MD5 算法
import hashlib # ######## md5 ######## hash = hashlib.md5() # help(hash.update) hash.update(bytes('admin', encoding='utf-8')) print(hash.hexdigest()) print(hash.digest()) ######## sha1 ######## hash = hashlib.sha1() hash.update(bytes('admin', encoding='utf-8')) print(hash.hexdigest()) # ######## sha256 ######## hash = hashlib.sha256() hash.update(bytes('admin', encoding='utf-8')) print(hash.hexdigest()) # ######## sha384 ######## hash = hashlib.sha384() hash.update(bytes('admin', encoding='utf-8')) print(hash.hexdigest()) # ######## sha512 ######## hash = hashlib.sha512() hash.update(bytes('admin', encoding='utf-8')) print(hash.hexdigest())
密码加盐
import hashlib # ######## md5 ######## hash = hashlib.md5(bytes('898oaFs09f',encoding="utf-8")) hash.update(bytes('admin',encoding="utf-8")) print(hash.hexdigest())