当前位置 主页 > 网站技术 > 代码类 >

    python 扩展print打印文件路径和当前时间信息的实例代码

    栏目:代码类 时间:2019-10-28 12:03

    pinrt函数我们经常使用,但是有时候python自带的print函数打印的信息不够详细,我们可以扩展一下,打印更多的信息,例如程序文件绝对路径、当前日期时间、消息等等。这里我参考了ydf网友写的猴子补丁(monkey patch)法。

    # -*- coding: utf-8 -*-
    # @Author : ydf
    # @Time  : 2019/5/9 19:02
    """
    不直接给print打补丁,自己重新赋值。
    """
    import sys
    import time
    # noinspection PyProtectedMember,PyUnusedLocal,PyIncorrectDocstring
    def nb_print(*args, sep=' ', end='\n', file=None):
      """
      超流弊的print补丁
      :param x:
      :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) for arg in args) # REMIND 防止是数字不能被join
      # 打印到标准输出,并设置文字和背景颜色
      sys.stdout.write(f'"{file_name}:{line}" {time.strftime("%H:%M:%S")} \033[0;94m{"".join(args)}\033[0m\n') # 36 93 96 94
    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打印文件路径和当前时间信息,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对IIS7站长之家网站的支持!
    如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!