本文目录:
一、logging模块
二、logging模块的使用
三、hashlib模块
四、re模块

一、logging模块

import logging

# 1 日志的级别
logging.debug("这是一个调试信息") #
logging.info("常规信息") #
logging.warning("警告信息") #
ogging.error("错误信息") #
logging.critical("严重错误") #
#
# 在logging模块中有对应的常量用来表示级别
# 默认情况下 默认的级别30 WARNING 日志的位置是控制台
#
# 2 自定义日志的配置
logging.basicConfig(
filename="a.log",
filemode="at",
level=10,
format="%(asctime)s %(levelname)s %(funcName)s %(lineno)s %(message)s",
datefmt="%Y-%m-%d %X %p") # logging.debug("这又是一个调试信息")
#
#日志模块的四个核心对象
"""
1.logger 日志生成器
2.filter 过滤器
3.handler 处理器
4.formater 格式处理器
"""
#
#1.创建一个日志生成器
mylog = logging.getLogger("mylog")
mylog.setLevel(logging.DEBUG)
#
# 2.建一个日志处理器
fh = logging.FileHandler("b.long",encoding="utf-8")
#
# 3.搞一个格式处理器
# fm = logging.Formatter(
# "%(asctime)s %(levelname)s %(funcName)s %(lineno)s %(message)s",
# datefmt="%Y-%m-%d %X %p")
#
# 4.将三个对象进行关联
mylog.addHandler(fh)
fh.setFormatter(fm)
# #测试
mylog.debug("mylog 的 测试") # 日志的继承
log1 = logging.getLogger("father")
log2 = logging.getLogger("father.son")
log3 = logging.getLogger("father.son.grandson") #默认值为True标识 有继承关系 当子的日志产生日志是 给他的父级以及父级以上都发了一份
#如果不需要就设置False
#log3.propagate = False fh = logging.FileHandler("c.long",encoding="utf-8") fm = logging.Formatter(
"%(asctime)s %(levelname)s %(funcName)s %(lineno)s %(message)s",
datefmt="%Y-%m-%d %X %p") log1.addHandler(fh)
log2.addHandler(fh)
log3.addHandler(fh) fh.setFormatter(fm) log1.warning("father.log")
log1.warning("father.son.log")
log3.warning("father.son.grandson")

二、logging模块的使用

import logging.config
#以字典来配置文件 传入一个字典对象 就不需要在编写上面那一堆代码 logging.config.dictConfig() #流处理器
log1 = logging.getlogger("a")
#输出到文件
fh = logging.StreamHandler()
#输出到控制台
sh = logging.StreamHandler() log1.addHandler(sh)
log1.addHandler(fh)
fm = logging.Formatter(
"%(asctime)s %(levelname)S %(funcName)s %(lineno)s %(message)s",
datetime = "%Y-%m-%d %X %p")
sh.selfFormatter(fm) log1.warning("测试2") import lib.common
logger = lib.common.log() def login():
logger.debug("测试 测试!") login()

srtting文件

standard_format="%(asctime)s %(levelname)S %(funcName)s %(lineno)s %(message)s"
simple_format="%(asctime)s %(message)s"
complete_format="%(asctime)s %(levelname)S %(funcName)s %(lineno)s %(thread)s %(process)s %(message)s"
logfile_path = r"d.log" LOGGING_DIC = {
'version': 1,
'formatters': {
'standard': {
'format': standard_format
},
'simple': {
'format': simple_format
},
"complete":{
"format": complete_format
}
},
'filters': {},
'handlers': {
'console': {
'level': 'DEBUG',
'class': 'logging.StreamHandler',
'formatter': 'simple'
},
'default': {
'level': 'DEBUG',
'class': 'logging.handlers.RotatingFileHandler',
'formatter': 'standard',
'filename': logfile_path, #
'maxBytes': 1024 * 1024 * 5, # 日志文件的最大大小为5M 超出后 换文件
'backupCount': 5, # 最多留五个日志文件
'encoding': 'utf-8',
},
},
'loggers': {
# 在getLogger的时候 如果指定的名称 不存在 或者不给名称 用的就是默认的
# 在这里如果key为空 它就是默认的
# 你可以自己定义生成器的名称 并且他们还能使用相同的默认配置
'': {
'handlers': ['default', 'console'],
'level': 'DEBUG',
'propagate': False,
},
},
}

三、hashlib模块

"""
    hash lib
    hash是一种算法  是将一个任意长的数据 根据计算 得到一个固定长度特征码
    特征: 不同输入 可能会有相同的结果 几率特别小
        相同的输入 必然得到相同结果
        由于散列(特征)的性质 从原理来看是不可能 反解
    用来 验证   两个输入的数据是否一致
    使用场景
    1.密码验证
                    123321   jahsajshajhsjahjas
                        client 加密后结果      server 拿到加密后
    2.验证数据是否被篡改 比如游戏安装包  有没有被改过
    为了防止别人撞库成功  可用提升密码的复杂度   其次可以为密码加盐 (加点内容进去)
"""
m = hashlib.md5("aaa".encode("utf-8"))
print(len(m.hexdigest())) # 撞库破解的原理 有人事先 把常见的 明文和密文的对应关系 存到了数据库中
# 运气好就能查询到
pwds = {"aaa":"47bce5c74f589f4867dbd57e9ca9f808"} h1 = hashlib.sha512("".encode("utf-8"))
h2 = hashlib.sha3_512("".encode("utf-8")) # print(len(h.hexdigest()))
print(h1.hexdigest())
print(h2.hexdigest()) # 2b70683ef3fa64572aa50775acc84855 # 加盐
m = hashlib.md5("".encode("utf-8"))
#加
m.update("abcdefplkjoujhh".encode("utf-8")) print(m.hexdigest()) import hmac
# 没啥区别 只是在创建的时候必须加盐
h = hmac.new("abcdefjjjj".encode("utf-8")) h.update("".encode("utf-8")) print(h.hexdigest())

四、re模块

"""
    re模块
    主要正则表达式相关
    什么是正则表达式  一堆带有特殊意义的符号组成式子
    它的作用 处理(匹配 查找 替换 )字符串
    1.
    在爬虫中大量使用 其实有框架帮你封装了这些复杂的正则
    2.
    在网站和手机app的注册功能中大量使用 例如判断你的邮箱地址是否正确
"""

import re

# ===============================单个字符匹配=========
print(re.findall("\n","1\n")) # 匹配换行符
print(re.findall("\t","1asasas121 \t")) # 匹配制表符 # ========================范围匹配===========
print(re.findall("\w","1aA_*")) # 匹配数字字母下划线
print(re.findall("\W","1aA_*,")) # 匹配非数字字母下划线
print(re.findall("\s"," \n\r\t\f")) # 匹配任意空白字符
print(re.findall("\S"," \n\r\t\f")) # 匹配任意非空白字符
print(re.findall("\d","123abc1*")) # 匹配任意数字
print(re.findall("\D","123abc1*")) # 匹配任意非数字
print(re.findall("[abc]","AaBbCc")) # 匹配 a b c都行
print(re.findall("[^abc]","AaBbCc")) # 除了 a b c都行
print(re.findall("[0-9]","AaBbCc12349")) # 匹配中括号内0-9的数字
print(re.findall("[a-z]","AaBbCc12349")) # 匹配小写字母a-z 英文字母
print(re.findall("[A-z]","AaBbC:c

python常用模块:logging、hashlib、re的更多相关文章

  1. Python常用模块之hashlib(加密)

    Python常用模块之hashlib(加密) Python里面的hashlib模块提供了很多加密的算法,这里介绍一下hashlib的简单使用事例,用hashlib的md5算法加密数据import ha ...

  2. Python常用模块之hashlib模块

    1.hashilib模块的功能 python的hashlib提供了常见的摘要算法,如MD5, SHA1等等. 什么是摘要算法呢?摘要算法又称哈希算法.散列算法.它通过一个函数,把任意长度的数据转换成一 ...

  3. python常用模块补充hashlib configparser logging,subprocess模块

    一.hashlib模板 Python的hashlib提供了常见的摘要算法,如MD5,SHA1等等. 什么是摘要算法呢?摘要算法又称哈希算法.散列算法.它通过一个函数,把任意长度的数据转换为一个长度固定 ...

  4. Python常用模块--logging

    (转载) 原文:http://www.cnblogs.com/dahu-daqing/p/7040764.html 1 logging模块简介 logging模块是Python内置的标准模块,主要用于 ...

  5. Python常用模块之hashlib

    Python里面的hashlib模块提供了很多加密的算法,这里介绍一下hashlib的简单使用事例,用hashlib的md5算法加密数据 import hashlib hash = hashlib.m ...

  6. python常用模块集合

    python常用模块集合 Python自定义模块 python collections模块/系列 Python 常用模块-json/pickle序列化/反序列化 python 常用模块os系统接口 p ...

  7. python 常用模块 time random os模块 sys模块 json & pickle shelve模块 xml模块 configparser hashlib subprocess logging re正则

    python 常用模块 time random os模块 sys模块 json & pickle shelve模块 xml模块 configparser hashlib  subprocess ...

  8. 常用模块之hashlib,configparser,logging模块

    常用模块二 hashlib模块 hashlib提供了常见的摘要算法,如md5和sha1等等. 那么什么是摘要算法呢?摘要算法又称为哈希算法.散列算法.它通过一个函数,把任意长度的数据转换为一个长度固定 ...

  9. Python常用模块-摘要算法(hashlib)

    Python常用模块-摘要算法(hashlib) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.MD5算法参数详解 1.十六进制md5算法摘要 #!/usr/bin/env p ...

  10. Python常用模块——目录

    Python常用模块学习 Python模块和包 Python常用模块time & datetime &random 模块 Python常用模块os & sys & sh ...

随机推荐

  1. JavaScript(7)——DOM

    什么是 DOM? DOM是 Document Object Model(文档对象模型)的缩写 DOM是 W3C(万维网联盟)的标准. DOM 定义了访问 HTML 和 XML 文档的标准: “W3C ...

  2. 使用mysqldump对mysql进行备份与恢复

    说明: 主参考:https://blog.csdn.net/fanren224/article/details/79693860 mysql数据全量备份 1.开启二进制日志,备份指定数据库 cat & ...

  3. day26 封装、多态、内置函数、反射、动态导入

    今日内容 1.封装 什么是封装? 封装从字面意思上看就只将某种东西封起来装好,当我们代码中的某些方法与属性不想让外界进行访问时,就对这些属性进行特殊的处理,使这种属性或者方法不能被外界直接进行访问或者 ...

  4. makefile中=、:=和+=的区别

    经常有人分不清= .:=和+=的区别  这里我总结下做下详细的分析: 首先你得清楚makefile的运行环境,因为我是linux系统,那么我得运行环境是shell 在Linux的shell里,shel ...

  5. Consecutive Numbers Sum

    Given a positive integer N, how many ways can we write it as a sum of consecutive positive integers? ...

  6. Spring学习笔记(一)

    Spring学习笔记(一) 这是一个沉淀的过程,大概第一次接触Spring是在去年的这个时候,当初在实训,初次接触Java web,直接学习SSM框架(当是Servlet都没有学),于是,养成了一个很 ...

  7. php修改替换数据库图片(文件)

    <?php extract($_POST); $date = date('Y-m-d'); $file_name = $_FILES['image']['name'];//获取缓存区图片,格式不 ...

  8. MySQ-表关系-外键-修改表结构-复制表-03

    目录 前言 不合理的表结构(案例) 带来的问题 如何解决问题? 如何确定表关系? 表关系 一对多 多对多 一对一 应用场景 判断表关系最简单的语法 三种关系常见案例 如何建立表关系? 外键 forei ...

  9. vue 模拟测试数据构建

    等价=====================================

  10. QT之QString的arg方法

    转载.标记一下,总结的很好 转自 http://www.cnblogs.com/lomper/p/4135387.html 在QT的QString中,arg方法类似于C中的printf中使用的格式输出 ...