Python训练模型时如何将实验日志保存在一个文件中

Python训练模型时如何将实验日志保存在一个文件中


问题描述

在训练模型时,想把终端打印出来的结果全部保存在一个实验日志中,方便以后查看。(如有更简便的方法请大家赐教,抱拳感谢!)

解决办法

1.首先创建一个实验结果的保存路径

output_dir = './ResultData'
os.makedirs(output_dir, exist_ok=True)

2.新建一个空的文件

timeslot = int(time.time())
dt = time.strftime("%Y%m%d%H%M%S", time.localtime(timeslot))
file = open(f'./ResultData/Baseline_01_exp{args.seed}_{args.dataset}_noniid[{args.degree_noniid}]_labelrate[{args.shot}]_FedavgFixmatch_{dt}_log.txt','w')

3.在print的时候,将其写入文件中(只写入文件中,终端不会打印结果),例如:

print('hello world',file=file)

文件中就会保存下来这句话,如图:
在这里插入图片描述
4.如果想在终端看到print的结果,把file=file去掉即可。

print('hello world')

在这里插入图片描述
以上是本人的笨办法,嘻嘻~

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
在PyTorch,我们可以使用Python自带的logging模块来保存模型训练过程日志信息。首先,我们需要导入logging模块: ```python import logging ``` 然后,设置日志的级别以及日志的格式: ```python # 设置日志级别为INFO logging.basicConfig(level=logging.INFO) # 设置日志的格式 formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s') ``` 接下来,我们可以创建一个logger对象,并设置其相关属性,比如日志级别和格式: ```python # 创建logger对象 logger = logging.getLogger() # 设置日志级别为INFO logger.setLevel(logging.INFO) # 创建一个文件日志处理器,并将日志写入指定文件 file_handler = logging.FileHandler('log.txt') file_handler.setLevel(logging.INFO) file_handler.setFormatter(formatter) # 创建一个控制台日志处理器,并将日志打印在控制台上 console_handler = logging.StreamHandler() console_handler.setLevel(logging.INFO) console_handler.setFormatter(formatter) # 将文件日志处理器和控制台日志处理器添加到logger对象 logger.addHandler(file_handler) logger.addHandler(console_handler) ``` 最后,在模型训练的迭代过程,我们可以使用logger对象来保存训练过程日志信息: ```python # 模型训练过程日志信息 for epoch in range(num_epochs): # 模型训练代码 # ... # 保存日志信息 logger.info(f'Epoch: {epoch}') # 模型评估代码 # ... # 保存日志信息 logger.info(f'Evaluation: {evaluation_result}') ``` 这样,模型训练过程日志信息就会被保存在'log.txt'文件,并且也会在控制台上进行打印。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

甜度超标°

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值