Python 重构Print 日志记录


Python 重构Print 日志记录

背景

Python Print方法中默认的不是太美观

重构一下,添加上输出的时间

效果如下:

Python 重构Print 日志记录

实现:

log.py

Python 全选
from time import strftime, localtime

def info(*values):
    timestr = strftime("%Y-%m-%d %H:%M:%S", localtime())
    print(timestr, " | ", *values)

# info('abc', '-', '123')

重点,支持 可变长参数

参考:https://www.cnblogs.com/SkyOceanchen/p/11336568.html

 

python函数之可变长参数 可变长参数

可变长参数:指的是在调用函数时,传入的参数个数可以不固定

调用函数时,传值的方式无非俩种,一种是位置实参,另一种是关键字实参,因此形参也必须得又俩种解决方法,以此来分别接收溢出的位置实参和关键字实参

1、可变长形参之*

形参中的*会将溢出的位置实参全部接受,然后以元组的形式存储,然后把元组赋值给*后的参数,需要注意的是*后的参数名约定成俗成为args

Python 全选
def sum_sef(*args):
    res = 0
    for num in args:
        res+=num
    return  res
res = sum_sef(1,2,3,4,5)#由于没有型参来接受实参的值,故全部给args
print(res)


#输出:15
Python 全选
def sum_sef(x,*args):
    res = 0
    for num in args:
        res+=num
    return  res
res = sum_sef(1,2,3,4,5) #形参x接受了1,剩下的实参没有形参接受
print(res)

#输出:14

2、可变长实参之*

实参中的*会将*后参数的值循环取出,打散成位置实参,以后但凡碰到实参中带有*的,就是位置实参,应该马上进行打散成位置实参去看。

Python 全选
def sum_sef(x,y,z,*args):
    print(x,y,z,args)
    print(args)			#arg中存储了(4,5,6)
    print(*args)       #输出的时候加上*可以去掉()
    print(type(args))  #args 是元组类型


sum_sef(1,*(2,3),4,5,6)   #将*号内元素打散成,1,2,3,4,5,6,对形参进行赋值

#输出:
1 2 3 (4, 5, 6)
(4, 5, 6)
4 5 6
<class 'tuple'>

3、可变长形参之**

形参中的**会将溢出的关键字实参全部接收,然后存储字典的形式,然后把字典赋值给**后的参数,需要注意的是**后的参数名约定成俗为kwargs

Python 全选
def func(x,y,**kwargs):
    print(kwargs)
func(7,8,a=5,b=6)

#输出:
{'a': 5, 'b': 6}

4、可变长实参之**

实参中的**,会将参数后面的值循环取出,打散成关键字实参,以后遇到实参中带有**的,就是关键字实参,应该马上就打散成关键字实参去看。

Python 全选
def func(x,y,b,**kwargs):  #形参中不可任意的添加值,比如z,因为在实参中并没有值和z对应
    print(x,y,b)
    print(kwargs)
func(7,8,**{'a': 5, 'b': 6,'c':7}) #打散后,由于形参中有b,因此提出b值,其余的赋值给**kwargs
#输出:
7 8 6
{'a': 5, 'c': 7}

5、可变长参数应用

Python 全选
def index(name,age,sex):
    print('name:',name,'age:',age,'sex:',sex)

def wrapper(*args,**kwargs):
    print('args:',args,'lwargs:',kwargs)

index('chen',18,'male')
wrapper(name='chen',sex='male',age=19)


#输出:
name chen age 18 sex male
args: () lwargs: {'name': 'chen', 'sex': 'male', 'age': 19}

6、命名关键字形参

Python 全选
def register(x,y,**kwargs):
    if 'name' not in kwargs or 'age' not in kwargs:
        print('用户名必须使用关键字的形式传值')
        return
    print(kwargs['name'])
    print(kwargs['age'])

register(12,13,name='chen',age='18')



#输出:
chen
18

命名关键字形参:在函数定义阶段,*后面的参数都是命名关键字参数

特点:在传值时,必须按照key=value的方式传值,并且key必须命名关键字参数的指定的参数。

Python 全选
def register(x, y, *, name, gender='male', age):
    print(x)
    print(y)
    #print(*)  #特殊字符无意义
    print(name)
    print(gender)
    print(age)


register(1, 2, name='nick', age=19)



#输出:
1
2
nick
male
19
版权声明:本文为YES开发框架网发布内容,转载请附上原文出处连接
管理员
上一篇:Node.js版本不对引起的 构建失败提示throw new ERR_INVALID_CALLBACK();
下一篇:Python百度检索获得真实的目的URL连接
评论列表

发表评论

评论内容
昵称:
关联文章

Python 重构Print 日志记录
YESWEB接口日志记录
C#错误异常日志记录到文件
在Winform项目和Web API的.NetCore项目中使用Serilog 来记录日志信息
版本记录
Python 打印日志格式,并且支持不同颜色和背景色
C#日志Log写入
Python Selenium ChromeDriver 规避检测
Winform开发框架日志管理
Python使用selenium+chrome配置指南
Python暂停程序执行
Python Selenium 抓包注入记录
Python修改cmd窗口标题
关于PaddleSharp GPU使用 常见问题记录
Python Selenium使用火狐浏览器驱动
WPF开发随笔收录-本地日志LogUtil类
使用 mitmproxy + python 做拦截代理
VScode配置Python开发环境
Python安装
Python __name__=='__main__'作用详解

联系我们
联系电话:15090125178(微信同号)
电子邮箱:garson_zhang@163.com
站长微信二维码
微信二维码