时间:2021-05-22
前言:
今天学习python的常用模块的时候,了解到了time模块和datetime模块,于是想在编译环境中实时打印出时间,不会换行,且打印的时候自动删除前一步打印出的时间(本质原理不是这样),而不是像print那样打印之后自动换行再重新打印。
想要直接看到效果及方法,请直接跳到后文 解决办法。
我们先来看看Print方法打印的效果:
代码:
from datetime import datetime as dtimport sysimport time for i in range(5): print(dt.now()) time.sleep(1)输出结果:
C:\Users\Administrator\PycharmProjects\untitled\venv\Scripts\python.exe C:/Users/Administrator/PycharmProjects/untitled/test.py2018-08-06 16:46:46.6362562018-08-06 16:46:47.6363132018-08-06 16:46:48.6363702018-08-06 16:46:49.6364272018-08-06 16:46:50.637484 Process finished with exit code 0可以看到,用print打印出来自动换行且不会清除上一个结果
help一下看看:
help(print)
输出:
print(...) print(value, ..., sep=' ', end='\n', file=sys.stdout, flush=False) Prints the values to a stream, or to sys.stdout by default. Optional keyword arguments: file: a file-like object (stream); defaults to the current sys.stdout. sep: string inserted between values, default a space. end: string appended after the last value, default a newline. flush: whether to forcibly flush the stream.可以看到end=“\n”表示了print自带换行
如果我想要在一行中打印一串信息,并且在下一次执行的时候删除这一行再重新打印(效果类似如此),该如何做呢?尝试清屏可不可以?
清屏试一试,查阅别的博客的方法有如下代码:
import os os.system('cls')但这是在命令行里使用的,用在编译器里不行。
解决办法
这时候就要用到sys.stdout.write了
使用如下方法:
from datetime import datetime as dtimport sysimport time while True: a = dt.now() sys.stdout.write("\r{0}".format(a)) sys.stdout.flush() time.sleep(1)以及:
from datetime import datetime as dtimport sysimport time for i in range(20): a = dt.now() sys.stdout.write("\r{0}".format(a)) sys.stdout.flush() sys.stdout.write('\033[4A') time.sleep(1)都可以实现实时打印。
其关键就在于使用'\r'这个转义字符(回到行首), sys.stdout.write首先打印这一行后不带任何结尾(前文已经说过print打印结尾带end="\n",表示自带换行,换行了就不能在对已经打印的这一行进行更改编辑),使用了转移字符"\r"使得光标回到行首,再把缓冲区显示出来,就得到了我们所需要的效果。
效果输出:
C:\Users\Administrator\PycharmProjects\untitled\venv\Scripts\python.exe C:/Users/Administrator/PycharmProjects/untitled/test.py2018-08-06 18:26:21.264878Run只会显示这一个,并且一秒钟更新一次。
这样就可以利用它来打印进度条。
进度条的特点:
- 有标刻度显示所占总进度比例
- 有百分比显示所占比例
代码示例:
import time,sys for i in range(100): percent = i / 100 sys.stdout.write("\r{0}{1}".format("|"*i , '%.2f%%' % (percent * 100))) sys.stdout.flush() time.sleep(1)输出效果:
|||||||||||||||||||||||||||||||||33.00%
拓展:Python小知识-sys.stdout.write和print进度条打印方式
打印进度条的方法用两种:
一、sys.stdout.write方式
这个方法中必须使用这句话每次来清理缓存。
sys.stdout.flush()
import sysimport timei = 0for i in range(20): time.sleep(1) sys.stdout.write("\r# Process: %0.1f %%" % (float(i + 1) / float(20) * 100)) sys.stdout.flush()二、print方式
其中用print('',end='')来实现sys.stdout.write()
import timei = 0for i in range(20): time.sleep(1) print("\r# Process: %0.1f %%" % (float(i + 1) / float(20) * 100),end="")结果如图1所示:
图1
三、\r等转义字符操作
以上这篇Python中的sys.stdout.write实现打印刷新功能就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
记录训练过程中的每一步的loss变化ifverboseandstep%verbose==0:sys.stdout.write('\r{}/{}:loss={}'
如下所示:importsys,timedefprint_one_by_one(text):sys.stdout.write("\r"+""*60+"\r")#/
假设我们有以下虚拟函数:importsysdefwriteline(text,stream=sys.stdout):stream.write(text+'')w
考虑以下python程序:复制代码代码如下:#!/usr/bin/envpythonimportsyssys.stdout.write("stdout1")sy
sed-i's/StreamHandler()/StreamHandler(sys.__stdout__)/'/opt/python/python3/lib/p