常用模块

random模块

import random
#取0-1的小数
print(random.random)
#取指定范围的整数
#random.randint(start_num,stop_num,step)
print(random.randint(1,10))

os模块

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.system("bash command")  运行shell命令,直接显示
os.popen("bash command).read()  运行shell命令,获取执行结果
os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径
os.chdir("dirname")  改变当前脚本工作目录;相当于shell下cd


os.path
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所指向的文件或者目录的最后修改时间
os.path.getsize(path) 返回path的大小

json模块

re模块

re.compile(patternflags=0)

将正则表达式的样式编译为一个 正则表达式对象 (正则对象),可以用于匹配,通过这个对象的方法match()search() 以及其他如下描述。

prog = re.compile(pattern)
result = prog.match(string)
等价于
result = re.match(pattern, string)

re.Ire.IGNORECASE

进行忽略大小写匹配;

re.search(patternstringflags=0)

扫描整个 字符串 找到匹配样式的第一个位置,并返回一个相应的 匹配对象

re.match(patternstringflags=0)

如果 string 开始的0或者多个字符匹配到了正则表达式样式,就返回一个相应的 匹配对象 。

re.fullmatch(patternstringflags=0)

如果整个 string 匹配到正则表达式样式,就返回一个相应的 匹配对象 。

re.split(patternstringmaxsplit=0flags=0)

用 pattern 分开 string 。 

re.findall(patternstringflags=0)

对 string 返回一个不重复的 pattern 的匹配列表, string 从左到右进行扫描,匹配按找到的顺序返回。

re.finditer(patternstringflags=0)

pattern 在 string 里所有的非重复匹配,返回为一个迭代器 iterator 保存了 匹配对象 。

re.sub(patternreplstringcount=0flags=0)

返回通过使用 repl 替换在 string 最左边非重叠出现的 pattern 而获得的字符串。

re.subn(patternreplstringcount=0flags=0)

行为与 sub() 相同,但是返回一个元组 (字符串, 替换次数).

官方文档:https://docs.python.org/zh-cn/3.7/library/re.html

hashlib模块

from hashlib import blake2b
h = blake2b('key'.encode('utf-8'))
h.update(b'Hello world')
h.update(b'ad')
print(h.hexdigest())
2adfada2605aed8014acb4691f0fc3e11593db4133b2a8f079dc817802b6b21e09d9e8d994a7c66782010686b0f194a60191d61caca82c6746ba68ed7031b0cc

logging模块

import time
import logging
class Log:
    def __init__(self):
        self.today = time.strftime("%Y-%m-%d",time.localtime())
        self.logger = logging.getLogger()
        self.logger.setLevel(logging.INFO)
        self.fh = logging.FileHandler('..\log\%s.log'%self.today,encoding='utf-8')
        self.fmt = logging.Formatter("%(asctime)s-%(levelname)s	-%(lineno)d-{}:%(message)s".format(__name__))
        self.fh.setFormatter(self.fmt)
        self.logger.addHandler(self.fh)
format参数中可能用到的格式化串:
%(name)s Logger的名字
%(levelno)s 数字形式的日志级别
%(levelname)s 文本形式的日志级别
%(pathname)s 调用日志输出函数的模块的完整路径名,可能没有
%(filename)s 调用日志输出函数的模块的文件名
%(module)s 调用日志输出函数的模块名
%(funcName)s 调用日志输出函数的函数名
%(lineno)d 调用日志输出函数的语句所在的代码行
%(created)f 当前时间,用UNIX标准的表示时间的浮 点数表示
%(relativeCreated)d 输出日志信息时的,自Logger创建以 来的毫秒数
%(asctime)s 字符串形式的当前时间。默认格式是 “2003-07-08 16:49:45,896”。逗号后面的是毫秒
%(thread)d 线程ID。可能没有
%(threadName)s 线程名。可能没有
%(process)d 进程ID。可能没有
%(message)s用户输出的消息

  

 

posted @ 2019-03-27 15:38  ☞Python☞  阅读(149)  评论(0编辑  收藏  举报