Python 上下文管理器:控制輸出的結果能同時保存到文件中

来源:https://www.cnblogs.com/JohnRain/archive/2018/12/08/10089419.html
-Advertisement-
Play Games

說明 以下這個類 可以修飾你的函數,讓你的函數或命令的輸出結果在控制台輸出的同時,還能存儲為你指定的文件 免去你是用寫日誌函數的必要 優點: 完全不需要修改代碼對函數或語句直接裝飾就行 直接修飾語句 修飾函數中的控制台輸出 以裝飾器的方式修飾輸出 結果 此內容為個人原創,轉載請註明出處:https: ...


說明

以下這個類print_and_save可以修飾你的函數,讓你的函數或命令的輸出結果在控制台輸出的同時,還能存儲為你指定的文件
免去你是用寫日誌函數的必要

優點:

  • 完全不需要修改代碼對函數或語句直接裝飾就行
import sys

class print_and_save(object):
    def __init__(self, filepath):
        self.file = open(filepath, 'a')
        self.old = sys.stdout  # 將當前系統輸出儲存到臨時變數
        sys.stdout = self

    def __enter__(self):
        pass

    def __call__(self,func):
        def wrapper(*args, **kwargs):
            frs = func(*args, **kwargs)
            self._exit()
            return frs
        return wrapper

    
    def write(self, message):
        self.old.write(message)
        self.file.write(message)

    def __exit__(self, exc_type, exc_val, exc_tb):
        self._exit()

    def _exit(self):
        self.file.flush()
        self.file.close()
        sys.stdout = self.old

直接修飾語句

with print_and_save("a.txt"):  
    print("directed print")

修飾函數中的控制台輸出

def contextout(text):
    print("context function print is %s" % text)

with print_and_save("a.txt"):  
    contextout("ok")

以裝飾器的方式修飾輸出

@print_and_save("a.txt")  
def decorated_out():
    print("decorator print")

decorated_out()

結果

# 控制台
directed print
context function print is ok
decorator print

# 文件a.txt內容
directed print
context function print is ok
decorator print

此內容為個人原創,轉載請註明出處:https://www.cnblogs.com/JohnRain/p/10089419.html


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 抽象工廠是基於簡單工廠發展而來的,通過抽象工廠,我們可以創建多種類型的工廠,並且依據具體業務需求而在具體工廠裡面進行任意拼裝組合。 介紹 在現實世界中,汽車製作行業有各種各樣的工廠,每個工廠都需要具有生產輪胎、汽車引擎等部件的能力,但是針對具體的工廠,每個部件的生產又各不相同,所有在軟體開發過程中, ...
  • 胡扯 因為先學習的treap,而splay與treap中有許多共性,所以會有很多地方不會講的很細緻。關於treap和平衡樹可以參考這篇博客 ...
  • Python編碼轉換問題;utf-8/gbk/unicode/ASCII ;統計字元串中數字,字母,漢字的個數 ...
  • Primer C++第五版 讀書筆記(一) (如有侵權請通知本人,將第一時間刪文) 1.1-2.2 章節 關於C++變數初始化: 初始化不是賦值,初始化的含義是創建變數時賦予其一個初始值,而賦值的含義是把對象的當前值擦除,以一個新值來替代. 定義一個名為a的int變數並初始化為0,有以下4種方法: ... ...
  • python安裝之後預設是使用國外的源,使用pip下載模塊網速不是很好,有時候下到一半還會斷開連接,非常不方便,最好配置國內的源。 Windows下: 在Windows配置源可參考下麵兩個博客: https://www.cnblogs.com/Devopser/p/6201292.html http ...
  • 對於表達式,分為“左結合”和“右結合” 左結合:對於沒有 = 號的,從左到右邊,當然要考慮優先順序。 右結合:對於有 = 號存在的情況,右邊的自成一體,然後賦值給左邊變數 優先順序: 邏輯運算符的優先順序: not > and > or a=1 b=2 c=2 not a or b + 2 == c (( ...
  • 迭代器:迭代器協議和可迭代協議,for 迴圈的運行邏輯,迭代器的好處 ...
  • Python基礎知識(26):常用內建模塊(Ⅱ) 1、hashlib Python的hashlib提供了常見的摘要演算法,如MD5,SHA1等 摘要演算法又稱哈希演算法、散列演算法。 (1)它通過一個函數,把任意長度的數據轉換為一個長度固定的數據串(通常用16進位的字元串表示) (2)摘要演算法就是通過摘要函 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...