当前位置: 首页 > 编程笔记 >

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

贺乐意
2023-03-14
本文向大家介绍python 扩展print打印文件路径和当前时间信息的实例代码,包括了python 扩展print打印文件路径和当前时间信息的实例代码的使用技巧和注意事项,需要的朋友参考一下

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打印文件路径和当前时间信息,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

 类似资料:
  • 问题内容: 我正在尝试获取有关系统上打印机的一些信息。 在Windows和Linux上,使用以下代码,仅填充属性: 在使用该功能之后… …这是结果: 如何获得更多信息 ,例如打印机注释? 问题答案: 还有其他实现,但是如果您想获取更多… 这只是一个 肮脏的 代码,您还可以获取不受支持的doc值: 注意: 您可能会看到重复的值,但是可以对其进行过滤。

  • 我正在开发一个Jenkins插件,但我有几个问题,我认为可能是由于插件的类路径中丢失了一个jar,尽管它在插件的WEB-INF/lib目录中。 通常,我会在Java中使用以下代码来打印类路径,但这似乎不适用于Jenkins。 当我执行插件时,上面的代码会导致一个异常与消息 打印Jenkins插件使用的类路径的最佳方式是什么?

  • 本文向大家介绍Python获取当前路径实现代码,包括了Python获取当前路径实现代码的使用技巧和注意事项,需要的朋友参考一下  Python获取当前路径实现代码 import os,sys 使用sys.path[0]、sys.argv[0]、os.getcwd()、os.path.abspath(__file__)、os.path.realpath(__file__) sys.path是Pyth

  • 问题内容: 我正在学习Python中的绳索。当我尝试使用该函数打印类的对象时,得到如下输出: 有没有办法设置类及其对象的打印行为(或字符串表示形式)?例如,当我调用类对象时,我想以某种格式打印其数据成员。如何在中实现? 如果你熟悉类,则可以通过为类ostream添加方法来实现上述目的。 问题答案: 该方法是在打印时发生的事情,该方法是在使用功能时(或在交互式提示下查看它时)发生的事情。如果这不是最

  • 例子 $ gcc -v foo.c ... ignoring nonexistent directory "/usr/local/include/x86_64-linux-gnu" ignoring nonexistent directory "/usr/lib/gcc/x86_64-linux-gnu/4.6/../../../../x86_64-linux-gnu/include" #incl

  • 问题内容: 我正在学习swift,并制作了一个表格,其中包含显示图像的单元格,以及按MIME TYPE(使用路径扩展名)分组的类。我有一个关于扩展的问题。如果图像(例如,可能是视频或pdf)是从Internet上获取的,我不确定它们是否具有扩展名, 如何在不使用路径扩展名的情况下获取文件系统中文件的MIME类型? PS:很抱歉我的英语不好,这不是我的母语 问题答案: 假设您以NSData的形式接收

  • 本文向大家介绍python代码打印100-999之间的回文数示例,包括了python代码打印100-999之间的回文数示例的使用技巧和注意事项,需要的朋友参考一下 打印100-999之间的回文数(即百位和个位的数字相等),并每10个打印一行 结果打印如下: 知识点归纳: 1.while循环基本语法: ------>明确基本结构三要素:开始标志,结束标志,自增数。 开始标志: # i = 100 w

  • Vimscript中,我们最先关注的是echo和echom命令。 你可以在Vim中执行:help echo和:help echom命令以查看其帮助文档。读完本书之后, 再次遇到新的命令时,你应该先执行:help命令查看其帮助文档。 执行如下命令,体验echo命令: :::vim :echo "Hello, world!" 你应该会在屏幕的底部看到Hello, world!被打印出来。 还是打印消