python 扩展print打印文件路径和当前时间信息的实例代码
pinrt函数我们经常使用,但是有时候python自带的print函数打印的信息不够详细,我们可以扩展一下,打印更多的信息,例如程序文件绝对路径、当前日期时间、消息等等。这里我参考了ydf网友写的猴子补丁(monkeypatch)法。
#-*-coding:utf-8-*-
#@Author:ydf
#@Time:2019/5/919:02
"""
不直接给print打补丁,自己重新赋值。
"""
importsys
importtime
#noinspectionPyProtectedMember,PyUnusedLocal,PyIncorrectDocstring
defnb_print(*args,sep='',end='\n',file=None):
"""
超流弊的print补丁
:paramx:
:return:
"""
#获取被调用函数在被调用时所处代码行数
line=sys._getframe().f_back.f_lineno
#获取被调用函数所在模块文件名
file_name=sys._getframe(1).f_code.co_filename
#sys.stdout.write(f'"{__file__}:{sys._getframe().f_lineno}"{x}\n')
args=(str(arg)forarginargs)#REMIND防止是数字不能被join
#打印到标准输出,并设置文字和背景颜色
sys.stdout.write(f'"{file_name}:{line}"{time.strftime("%H:%M:%S")}\033[0;94m{"".join(args)}\033[0m\n')#36939694
print=nb_print#这是打猴子补丁。
if__name__=='__main__':
print(0)
nb_print(123,'abc')
print=nb_print
print(456,'def')
实例:
"D:/monkey_print2.py:31" 14:40:34 0
"D:/monkey_print2.py:32" 14:40:34 123abc
"D:/monkey_print2.py:34" 14:40:34 456def
总结
以上所述是小编给大家介绍的python扩展print打印文件路径和当前时间信息,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!