python 擴(kuò)展print打印文件路徑和當(dāng)前時(shí)間信息的實(shí)例代碼
pinrt函數(shù)我們經(jīng)常使用,但是有時(shí)候python自帶的print函數(shù)打印的信息不夠詳細(xì),我們可以擴(kuò)展一下,打印更多的信息,例如程序文件絕對(duì)路徑、當(dāng)前日期時(shí)間、消息等等。這里我參考了ydf網(wǎng)友寫(xiě)的猴子補(bǔ)丁(monkey patch)法。
# -*- coding: utf-8 -*- # @Author : ydf # @Time : 2019/5/9 19:02 """ 不直接給print打補(bǔ)丁,自己重新賦值。 """ import sys import time # noinspection PyProtectedMember,PyUnusedLocal,PyIncorrectDocstring def nb_print(*args, sep=' ', end='\n', file=None): """ 超流弊的print補(bǔ)丁 :param x: :return: """ # 獲取被調(diào)用函數(shù)在被調(diào)用時(shí)所處代碼行數(shù) line = sys._getframe().f_back.f_lineno # 獲取被調(diào)用函數(shù)所在模塊文件名 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 防止是數(shù)字不能被join # 打印到標(biāo)準(zhǔn)輸出,并設(shè)置文字和背景顏色 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 # 這是打猴子補(bǔ)丁。 if __name__ == '__main__': print(0) nb_print(123, 'abc') print = nb_print print(456, 'def')
實(shí)例:
"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
總結(jié)
以上所述是小編給大家介紹的python 擴(kuò)展print打印文件路徑和當(dāng)前時(shí)間信息,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
Python自動(dòng)發(fā)送郵件的方法實(shí)例總結(jié)
這篇文章主要介紹了Python自動(dòng)發(fā)送郵件的方法,結(jié)合實(shí)例形式總結(jié)分析了Python使用smtplib和email模塊發(fā)送郵件的相關(guān)使用技巧與操作注意事項(xiàng),需要的朋友可以參考下2018-12-12python pandas讀取csv后,獲取列標(biāo)簽的方法
今天小編就為大家分享一篇python pandas讀取csv后,獲取列標(biāo)簽的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-11-11關(guān)于Python排序問(wèn)題(冒泡/選擇/插入)
這篇文章主要介紹了關(guān)于Python排序問(wèn)題(冒泡/選擇/插入),學(xué)過(guò)C語(yǔ)言肯定接觸過(guò)排序問(wèn)題,我們最常用的也就是冒泡排序、選擇排序、插入排序,需要的朋友可以參考下2023-04-04Python二叉樹(shù)的遍歷操作示例【前序遍歷,中序遍歷,后序遍歷,層序遍歷】
這篇文章主要介紹了Python二叉樹(shù)的遍歷操作,結(jié)合實(shí)例形式分析了Python針對(duì)二叉樹(shù)的前序遍歷,中序遍歷,后序遍歷,層序遍歷等相關(guān)操作實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-12-12python統(tǒng)計(jì)mysql數(shù)據(jù)量變化并調(diào)用接口告警的示例代碼
這篇文章主要介紹了python統(tǒng)計(jì)mysql數(shù)據(jù)量變化并調(diào)用接口告警的示例代碼,幫助大家更好的利用python操作數(shù)據(jù)庫(kù),感興趣的朋友可以了解下2020-09-092018年P(guān)ython值得關(guān)注的開(kāi)源庫(kù)、工具和開(kāi)發(fā)者(總結(jié)篇)
本文給大家總結(jié)了2018年P(guān)ython值得關(guān)注的開(kāi)源庫(kù)、工具和開(kāi)發(fā)者,需要的朋友可以參考下2018-01-01pyside+pyqt實(shí)現(xiàn)鼠標(biāo)右鍵菜單功能
這篇文章主要為大家詳細(xì)介紹了pyside+pyqt實(shí)現(xiàn)鼠標(biāo)右鍵菜單功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-02-02