模块 logging random

模块logging

    logging模块的主要功能是记录软件调试、操作过程中的各种日志。
    默认情况下Python的logging模块将日志打印到了标准输出中,且只显示了大于等于WARNING级别的日志,这说明默认的日志级别设置为WARNING(日志级别等级CRITICAL > ERROR > WARNING > INFO > DEBUG),
默认的日志格式为日志级别:Logger名称:用户输出消息。
logging.basicConfig()函数中可通过具体参数来更改logging模块默认行为,
可用参数有:

filename:用指定的文件名创建FiledHandler,这样日志会被存储在指定的文件中。
filemode:文件打开方式,在指定了filename时使用这个参数,默认值为“a”还可指定为“w”。
format:指定handler使用的日志显示格式。
datefmt:指定日期时间格式。
level:设置rootlogger(后边会讲解具体概念)的日志级别
stream:用指定的stream创建StreamHandler。
    可以指定输出到sys.stderr,sys.stdout或者文件(f=open(‘test.log’,’w’)),默认
    为sys.stderr。若同时列出了filename和stream两个参数,则stream参数会被忽略。

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用户输出的消息

# 修改日志记录级别
logging.basicConfig(
     level=logging.DEBUG,# 级别要大写
  )

# 函数版日志模板
import logging
logging.basicConfig(
    # level=logging.WARNING,   # 默认日志级别
    level=logging.DEBUG,       # 修改日志级别
    format = ‘%(asctime)s - %(name)s - [%(lineno)d] - %(message)s‘,
    filename = "test.log",     # 日志文件名
    filemode = "w"             # 日志文件操作模式
)
logging.DEBUG("这是调试级别")     # debug调试级别,对应表示参数10
logging.INFO("这是信息级别")      # 日常信息级别,对应表示参数20
logging.WARNING("这是警告级别")   # 警告级别,对应表示参数30
logging.ERROR("这是错误级别")     # 错误级别,对应表示参数40
logging.CRITICAL("这是严重级别")  # 严重级别,对应表示参数50

# 结果为:
2019-01-16 18:23:56,605 - root - [11] - 这是调试级别
2019-01-16 18:23:56,605 - root - [12] - 这是信息级别
2019-01-16 18:23:56,606 - root - [13] - 这是警告级别
2019-01-16 18:23:56,606 - root - [14] - 这是错误级别
2019-01-16 18:23:56,606 - root - [15] - 这是严重级别

1、format = ‘%(asctime)s - %(name)s - [%(lineno)d] - %(message)s‘
          # 日志时间      操作人      运行行数     提示日志信息
2、当前配置,写到文件和打印到屏幕,只能二选一
3、文件写入的默认编码方式是GBK格式,不支持修改

# 自定义版本
import logging
logger = logging.getLogger("操作日志")#获取一个新的日志
formatter = logging.Formatter(‘%(asctime)s - %(name)s - [%(lineno)d] - %(message)s‘)
#定义一个模板

ch = logging.StreamHandler()#生成一个屏幕流
fh = logging.FileHandler("test.log","a","utf-8")#生成一个文件流

ch.setFormatter(formatter)#把定义的模板添加给屏幕流
fh.setFormatter(formatter)#把定义的模板添加给文件流

logger.setLevel(logging.DEBUG)#更改日志记录级别

logger.addHandler(ch)#将以屏幕流方式输出日志
logger.addHandler(fh)#将以文件流方式输出日志

logger.debug("这是调试级别")
logger.info("这是信息级别")
logger.warning("这是警告级别")
logger.error("这是错误级别")
logger.critical("这是严重级别")

###########也可以单独为其他角色定制个性化的模板来分开展示########
# 定制一个给领导的日志文件流模板
boss_formatter = logging.Formatter(‘%(asctime)s - %(message)s‘)

# 文件流写到对应的文件路径
boos = logging.FileHandler("boss.log","a","utf-8")

# 把定义的模板添加给领导文件流
boss.setFormatter(boss_formatter)

#将领导文件流加入日志绑定
logger.addHandler(boos)

模块random

import random
print(random.random())          # 0-1之间的小数
print(random.uniform(1,5))      # 1-5之间的小数

print(random.randint(1,36))     # 随机整数
print(random.randrange(1,10,2)) # randrange()指定范围,仅取奇数
print(random.randrange(0,10,2)) # randrange()指定范围,仅取偶数

import random
lst = [12,3,4,5,6,7]
# 随机取列表中的元素
print(lst[random.randrange(len(lst))])  # 随机取列表的下标,再取元素
print(random.choice(lst))               # 简单方法,直接取

# 随机取列表中的2个元素
print(random.choice(lst),random.choice(lst))   # 会存在重复
print(random.choices(lst,k=2))   # 可以出现多个,但是容易重复
print(random.sample(lst,k=3))   # 可以出现多个,不会出现重复
# 同时,如果列表中存在列表或者其他对象的元素,也会整体取到,不会打散

# 顺序打散(洗牌)
import random
lst = [12,3,4,5,6,7]
random.shuffle(lst)  # 顺序打乱   洗牌
print(lst)
# 在此,集合已经不适用,集合已经序列化。

# 验证码,随机大写字母
import random
print(chr(random.randrange(65,91)))  # 先随机字母的ASCII码,再取字母

# 生成随机验证码
import random?
def v_code():?
    code = ‘‘
    for i in range(5):?
        num=random.randint(0,9)
        alf=chr(random.randint(65,90))
        add=random.choice([num,alf])
        code="".join([code,str(add)])?
    return code
?
print(v_code())

原文地址:https://www.cnblogs.com/LMTlmt/p/10285337.html

时间: 2024-08-11 15:24:13

模块 logging random的相关文章

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 logging re正则 转自老男孩老师Yuan:http://www.cnblogs.com/yuanchenqi/articles/5732581.html 模块&包(* * * * *) 模块(modue)的概念: 在计算机程序的开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,

python第十七天---时间模块、random模块

作完一个作业,开始新的学习: 有由今天的时间有限所有学习了以下两个模块,明天继续! 时间模块.random模块 import time 1 #!usr/bin/env python 2 #-*-coding:utf-8-*- 3 # Author calmyan 4 import time ,datetime 5 print(time.process_time())#测量处理器运算时间,不包括sleep时间 6 7 print(time.altzone)#返回与UTC时间的时间差 以秒计算 8

python日志模块-logging

日志模块 logging logging模块主要可以根据自定义日志信息,在程序运行的时候将日志打印在终端及记录日志到文件中.在这先了解一下logging支持的日志五个级别 debug() 调试级别,一般用于记录程序运行的详细信息 info() 事件级别,一般用于记录程序的运行过程 warnning() 警告级别,,一般用于记录程序出现潜在错误的情形 error() 错误级别,一般用于记录程序出现错误,但不影响整体运行 critical 严重错误级别 , 出现该错误已经影响到整体运行 简单用法,将

Python之配置日志模块logging

一.定义日志打印方式 如果我们运行自己的程序,有时候需要记录程序运行过程中出现的问题或者信息.可以运用日志模块logging来记录,该模块日志格式可以根据用户需求来自己定义. 常见打印日志信息形式如下: import logging logging.debug("========定义要打印的内容====debug①===========") logging.info("=========定义要打印的内容====info②===========") logging.w

内建模块:random

random随机模块 >>> import random    导入模块 >>> random.random()    随机生成一个浮点数 0.30851751369227465 >>> random.randrange(6)  随机生成0-5的数字 2 >>> random.choice('abcdefg') 随机生成一个字母 'c' >>> random.sample(xrange(100), 3) 不重复随机抽

Python常用模块-随机数模块(random)

Python常用模块-随机数模块(random) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.常用方法举例 1 #!/usr/bin/env python 2 #_*_coding:utf-8_*_ 3 #@author :yinzhengjie 4 #blog:http://www.cnblogs.com/yinzhengjie/tag/python%E8%87%AA%E5%8A%A8%E5%8C%96%E8%BF%90%E7%BB%B4%E4%B9%8B%E8%B7

Python标准模块--logging(转载)

转载地址:http://www.cnblogs.com/zhbzz2007/p/5943685.html#undefined Python标准模块--logging 1 logging模块简介 logging模块是Python内置的标准模块,主要用于输出运行日志,可以设置输出日志的等级.日志保存路径.日志文件回滚等:相比print,具备如下优点: 可以通过设置不同的日志等级,在release版本中只输出重要信息,而不必显示大量的调试信息: print将所有信息都输出到标准输出中,严重影响开发者从

python常用模块——logging

日志模块 logging 默认情况下Python的logging模块的日志级别是warning,默认输出到标准输出stdout 默认的日志格式为 日志级别:Logger名称:用户输出消息: 设置logging的默认格式及输出位置使用basicConfig方法. 一. logging模块的常用方法 1. basicConfig(**kwargs) 配置日志基本配置:参数可以是如下: filename:用指定的文件名创建FiledHandler(后边会具体讲解handler的概念),这样日志会被存储

python开发【八】---模块time&random

模块导入方法 1. 1 import 语句:import 模块 Python解释器的路径是sys.path 2. from…import 语句 from modname import name1 不会把整个modulename模块导入到当前的命名空间中,只会将它里面的name1单个引入到执行这个声明的模块的全局符号表. 3. from…import* 语句 from modname import * __name__ 在执行文件中打印是字符串__main__ 在被调用文件中打印就是被调用文件的路