python自动化运维(4)模块基础

网友投稿 883 2022-10-03

本站部分文章、图片属于网络上可搜索到的公开信息,均用于学习和交流用途,不能代表睿象云的观点、立场或意见。我们接受网民的监督,如发现任何违法内容或侵犯了您的权益,请第一时间联系小编邮箱jiasou666@gmail.com 处理。

python自动化运维(4)模块基础

模块导包

同一个包下导包

import abcfrom abc import abc

不同包下(这里举例是往上找了两个目录)

import osimport sysbase_dir=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))print(os.path.abspath(__file__))sys.path.append(base_dir)print(sys.path)

这里有三个知识点

当一个包下的模块互相调用的时候只需要import 模块名即可,当不同包下的时候就会报错。为了避免这个情况我们用上面的一段代码手动添加找包路径。

os.path.abspath(__file__)获取当前执行脚本的绝对路径。

os.path.dirname(path)获取path路径的上一目录。

sys.path.append(path)将路径添加到找包路径中

sys.path()获取当前的执行查找目录优先级,这里会返回一个存路径的列表。查找从前到后,前面获取的路径下获取到了就会顶替后面的。但是有些方法是写到解释器里的比如time.time方法。这里优先级比第一路径还要高。所以模块起名字的时候要避开一些python提供的模块。

星星星

from 包   import  *  自动加载包里面的__init__文件里所有的变量。

__all__可以限制被加载的变量,

__all__ = ["x","y"]

这样设置后import * 则只能加载x,y

hashlib模块

摘要算法

创建一个hashlib对象

hmd=hashlib.md5("这里可以加沿")后面所有的update都是在这个基础上增加目的就是防止用户设置密码过于简单被盗。

hmd.update(a这里填写加密信息)

hmd.update(a这里填写加密信息)

后面还有update的话会在上面的基础上加上新update。等同于

hmb.update(ab)

sys模块

直接偷图

OS模块

这个没偷到图

1

os.access(path, mode)

检验权限模式
2

os.chdir(path)

改变当前工作目录
3

os.chflags(path, flags)

设置路径的标记为数字标记。
4

os.chmod(path, mode)

更改权限
5

os.chown(path, uid, gid)

更改文件所有者
6

os.chroot(path)

改变当前进程的根目录
7

os.close(fd)

关闭文件描述符 fd
8

os.closerange(fd_low, fd_high)

关闭所有文件描述符,从 fd_low (包含) 到 fd_high (不包含), 错误会忽略
9

os.dup(fd)

复制文件描述符 fd
10

os.dup2(fd, fd2)

将一个文件描述符 fd 复制到另一个 fd2
11

os.fchdir(fd)

通过文件描述符改变当前工作目录
12

os.fchmod(fd, mode)

改变一个文件的访问权限,该文件由参数fd指定,参数mode是Unix下的文件访问权限。
13

os.fchown(fd, uid, gid)

修改一个文件的所有权,这个函数修改一个文件的用户ID和用户组ID,该文件由文件描述符fd指定。
14

os.fdatasync(fd)

强制将文件写入磁盘,该文件由文件描述符fd指定,但是不强制更新文件的状态信息。
15

os.fdopen(fd[, mode[, bufsize]])

通过文件描述符 fd 创建一个文件对象,并返回这个文件对象
16

os.fpathconf(fd, name)

返回一个打开的文件的系统配置信息。name为检索的系统配置的值,它也许是一个定义系统值的字符串,这些名字在很多标准中指定(POSIX.1, Unix 95, Unix 98, 和其它)。
17

os.fstat(fd)

返回文件描述符fd的状态,像stat()。
18

os.fstatvfs(fd)

返回包含文件描述符fd的文件的文件系统的信息,像 statvfs()
19

os.fsync(fd)

强制将文件描述符为fd的文件写入硬盘。
20

os.ftruncate(fd, length)

裁剪文件描述符fd对应的文件, 所以它最大不能超过文件大小。
21

os.getcwd()

返回当前工作目录
22

os.getcwdu()

返回一个当前工作目录的Unicode对象
23

os.isatty(fd)

如果文件描述符fd是打开的,同时与tty(-like)设备相连,则返回true, 否则False。
24

os.lchflags(path, flags)

设置路径的标记为数字标记,类似 chflags(),但是没有软链接
25

os.lchmod(path, mode)

修改连接文件权限
26

os.lchown(path, uid, gid)

更改文件所有者,类似 chown,但是不追踪链接。
27

os.link(src, dst)

创建硬链接,名为参数 dst,指向参数 src
28

os.listdir(path)

返回path指定的文件夹包含的文件或文件夹的名字的列表。
29

os.lseek(fd, pos, how)

设置文件描述符 fd当前位置为pos, how方式修改: SEEK_SET 或者 0 设置从文件开始的计算的pos; SEEK_CUR或者 1 则从当前位置计算; os.SEEK_END或者2则从文件尾部开始. 在unix,Windows中有效
30

os.lstat(path)

像stat(),但是没有软链接
31

os.major(device)

从原始的设备号中提取设备major号码 (使用stat中的st_dev或者st_rdev field)。
32

os.makedev(major, minor)

以major和minor设备号组成一个原始设备号
33

os.makedirs(path[, mode])

递归文件夹创建函数。像mkdir(), 但创建的所有intermediate-level文件夹需要包含子文件夹。
34

os.minor(device)

从原始的设备号中提取设备minor号码 (使用stat中的st_dev或者st_rdev field )。
35

os.mkdir(path[, mode])

以数字mode的mode创建一个名为path的文件夹.默认的 mode 是 0777 (八进制)。
36

os.mkfifo(path[, mode])

创建命名管道,mode 为数字,默认为 0666 (八进制)
37

os.mknod(filename[, mode=0600, device])
创建一个名为filename文件系统节点(文件,设备特别文件或者命名pipe)。

38

os.open(file, flags[, mode])

打开一个文件,并且设置需要的打开选项,mode参数是可选的
39

os.openpty()

打开一个新的伪终端对。返回 pty 和 tty的文件描述符。
40

os.pathconf(path, name)

返回相关文件的系统配置信息。
41

os.pipe()

创建一个管道. 返回一对文件描述符(r, w) 分别为读和写
42

os.popen(command[, mode[, bufsize]])

从一个 command 打开一个管道
43

os.read(fd, n)

从文件描述符 fd 中读取最多 n 个字节,返回包含读取字节的字符串,文件描述符 fd对应文件已达到结尾, 返回一个空字符串。
44

os.readlink(path)

返回软链接所指向的文件
45

os.remove(path)

删除路径为path的文件。如果path 是一个文件夹,将抛出OSError; 查看下面的rmdir()删除一个 directory。
46

os.removedirs(path)

递归删除目录。
47

os.rename(src, dst)

重命名文件或目录,从 src 到 dst
48

os.renames(old, new)

递归地对目录进行更名,也可以对文件进行更名。
49

os.rmdir(path)

删除path指定的空目录,如果目录非空,则抛出一个OSError异常。
50

os.stat(path)

获取path指定的路径的信息,功能等同于C API中的stat()系统调用。
51

os.stat_float_times([newvalue])
决定stat_result是否以float对象显示时间戳

52

os.statvfs(path)

获取指定路径的文件系统统计信息
53

os.symlink(src, dst)

创建一个软链接
54

os.tcgetpgrp(fd)

返回与终端fd(一个由os.open()返回的打开的文件描述符)关联的进程组
55

os.tcsetpgrp(fd, pg)

设置与终端fd(一个由os.open()返回的打开的文件描述符)关联的进程组为pg。
56

os.tempnam([dir[, prefix]])

返回唯一的路径名用于创建临时文件。
57

os.tmpfile()

返回一个打开的模式为(w+b)的文件对象 .这文件对象没有文件夹入口,没有文件描述符,将会自动删除。
58

os.tmpnam()

为创建一个临时文件返回一个唯一的路径
59

os.ttyname(fd)

返回一个字符串,它表示与文件描述符fd 关联的终端设备。如果fd 没有与终端设备关联,则引发一个异常。
60

os.unlink(path)

删除文件路径
61

os.utime(path, times)

返回指定的path文件的访问和修改的时间。
62

os.walk(top[, topdown=True[, onerror=None[, followlinks=False]]])

输出在文件夹中的文件名通过在树中游走,向上或者向下。
63

os.write(fd, str)

写入字符串到文件描述符 fd中. 返回实际写入的字符串长度
64

os.path 模块

获取文件的属性信息。

logging模块

日志等级:使用范围FATAL:致命错误CRITICAL:特别糟糕的事情,如内存耗尽、磁盘空间为空,一般很少使用ERROR:发生错误时,如IO操作失败或者连接问题WARNING:发生很重要的事件,但是并不是错误时,如用户登录密码错误INFO:处理请求或者状态变化等日常事务DEBUG:调试过程中使用DEBUG等级,如算法中每个循环的中间状态

import logging  #加载logging模块logger = logging.getLogger(__name__)  #创建日志器__name__处填写日志器名称logger.setLevel(level=logging.INFO)   #设置日志器级别#当有多个具有相同名称的日志器,调用任一日志器时将返回对同一记录器对象的引用#创建处理器,并设置级别。handler = logging.FileHandler("abc.txt", encoding='UTF-8') handler.setLevel(level=logging.INFO)#创建处理器并设置级别。console = logging.StreamHandler()console.setLevel(level=logging.ERROR)#设置一个输出格式对象formatter = logging.Formatter(fmt="%(asctime)s %(name)s ::: %(message)s", datefmt="%Y/%m/%d %X" )handler.setFormatter(formatter)#两个流分别添加输出格式如果不想一样可以设置两个输出格式对象。console.setFormatter(formatter)#日志器添加处理器logger.addHandler(handler)logger.addHandler(console)logger.info("info")logger.error("error")logger.warning("waring")

上述代码执行后会发现终端中只显示error文件中则会全部显示。

但是切记如果你把logging对象的级别也改为ERROR你会发现文件中也只显示ERROR。

我感觉是这么个情况,如果输出流对象没有设置级别的时候按logging对象级别走,设置的话谁的级别高就按谁的走。

日志格式配置里可用的信息

参考链接

https://blog.csdn.net/weixin_47154909/article/details/106203639

上一篇:【雄文】DevOps 能力模型、演进及案例剖析 | 高效运维
下一篇:玩转城市大脑,智能运维手到擒来
相关文章

 发表评论

暂时没有评论,来抢沙发吧~