"""问题:
1.输出日志的代码 分别是那些日志级别
2.希望输出在哪里 控制台 文件
3.希望从日志里看到的内容 日志呈现格式
日志级别:
Critical/Fatal(致命)>Error(报错)>Warning(警告)>Info(信息)>Debug(调试)
如果指定收集Warning以上的日志级别 那么会输出Warning>Error>Fatal
日志写入:
logger.add(文件路径)
设置日志大小
大小参数:rotation
个数参数:retention
压缩参数:compression #压缩后缀:zip tar gz等
logger.add(文件路径,rotation = '100 MB',retention=10,compression='zip')
logger.add(文件路径,rotation='00:00') 每天晚上12点重新生成一个日志文件
logger.add(文件路径,rotation='1 week')
logger.add(文件路径,rotation='10 days')

异常追溯:能够将异常和错误记录 还可以将对异常进行追溯
diagnose
backtrace
(exception)
"""


import os
import unittestreport
import unittest
from loguru import logger
logger.info("hello python")

logger.info("普通日志级别") # info级别日志
logger.error("报错") # error级别日志
logger.warning("警告") # warn警告级别日志
logger.debug("输出内容较详细") # debug级别日志
logger.critical("崩溃") # critical级别日志

logger.add("my_case.login",
rotation='100 MB', # 日志文件最大容量
retention=10, # 日志保留的时间
compression='zip',
diagnose=True,
backtrace=True,
encoding='utf-8', # 语言格式
level="INFO")


report_dir = os.path.join(os.path.dirname(os.path.dirname(__file__)), "reportsii")
# 测试报告生成的路径 以及测试报告的文件夹名字
s = unittest.defaultTestLoader.discover(os.path.join(os.path.dirname(__file__)))
# 加载测试报告的路径
runner = unittestreport.TestRunner(s, report_dir=report_dir)
runner.run()

eval函数

"""
eval(表达式) 用于字符串
1.去掉引号 按照python的语法执行
2.计算能力
"""

ss = '{"code":1,"msg":"您输入的为空"}'
my_dict = eval(ss)
print(my_dict)
print(type(my_dict))

ss = "100+200"
ret = eval(ss)
print(ret)

ss = "float(200)+1000"
res = eval(ss)
print(res)

ss = "print('6666')"
res = eval(ss)
print(res)