当前位置:主页 > python教程 > python在控制台输出

python的print输出在控制台并且将输出内容保存为文件(最新推荐)

发布:2023-04-25 18:05:01 59


为网友们分享了相关的编程文章,网友毋岚翠根据主题投稿了本篇教程内容,涉及到python在控制台输出、python将控制台输出保存到文件、python在控制台输出相关内容,已被447网友关注,下面的电子资料对本篇知识点有更加详尽的解释。

python在控制台输出

前言

深度学习log日志还是蛮重要的,print出来还不够,还得保存一下,目前找到的最方便的就如下所示了。

实现思路

我感觉就是类似于重写一下调用print的时候执行的方法,让他既能够在控制台输出,也能保存到文件里去

实现方法

定义一个Logger类

import sys  # 需要引入的包

# 以下为包装好的 Logger 类的定义
class Logger(object):
    def __init__(self, filename="Default.log"):
        self.terminal = sys.stdout
        self.log = open(filename, "w", encoding="utf-8")  # 防止编码错误

    def write(self, message):
        self.terminal.write(message)
        self.log.write(message)

    def flush(self):
        pass

计算时间戳,用于当我们的文件名,这样就不容易重名,方便数据的保存

import time  
t = time.strftime("-%Y%m%d-%H%M%S", time.localtime())  # 时间戳
filename = 'log' + t + '.txt'

紧接着需要实例化对象:

log = Logger(filename)  

然后将sys里的东西偷偷换成我们写的:

print("hi icy hunter")

接下来为所欲为的print就行了

print("hi icy hunter")

完整代码:

import sys  # 需要引入的包

# 以下为包装好的 Logger 类的定义
class Logger(object):
    def __init__(self, filename="Default.log"):
        self.terminal = sys.stdout
        self.log = open(filename, "w", encoding="utf-8")  # 防止编码错误

    def write(self, message):
        self.terminal.write(message)
        self.log.write(message)

    def flush(self):
        pass

import time  
t = time.strftime("-%Y%m%d-%H%M%S", time.localtime())  # 时间戳
filename = 'log' + t + '.txt'

log = Logger(filename)  
sys.stdout = log

print("hi icy hunter")

放到.py里运行一下:
控制台输出:

在这里插入图片描述

在这里插入图片描述

生成了这么个文件
点开看看:

在这里插入图片描述

嗯,是我想要的结果了。

ps:发现在ipynb里运行好像文件为空,可能是线程没结束,还没来得及写吧,不太清楚,不过要是用ipynb应该就不愁保存print了吧…

到此这篇关于python的print输出在控制台并且将输出内容保存为文件的文章就介绍到这了,更多相关python在控制台输出内容请搜索码农之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持码农之家!


参考资料

相关文章

网友讨论