关于 curses 文字排布小问题
本帖最后由 兰竹皋 于 2020-11-19 18:21 编辑最近练习爬虫时,用tqdm总会造成像是:多线程运行时数据排版不确定,数据缺失之类的问题(进度条还没满,任务内容已经完成了),于是就想自己写个类似的程序。
用curses时,发现输出中文文字时,文字重叠现象,例:
代码如下:
import curses
def get_ch_and_continue(stdscr):
stdscr.nodelay(0)
ch = stdscr.getch()
stdscr.nodelay(1)
print('main start')
try:
# 创建 curses
stdscr = curses.initscr()
curses.cbreak()
curses.noecho()
stdscr.keypad(1)
stdscr.addstr(0,0,'观天之道,执天之行,尽矣。天有五贼,见之者昌。')
stdscr.addstr(1,0,' '.join('观天之道,执天之行,尽矣。天有五贼,见之者昌。 '))
get_ch_and_continue(stdscr)
# 关闭 curses
curses.nocbreak()
curses.echo()
stdscr.keypad(0)
curses.endwin()
except Exception as e:
curses.nocbreak()
curses.echo()
stdscr.keypad(0)
curses.endwin()
print('main over')
如上图第一行,于是我想到多加一个空格使每个文件多占一个空位,如第二行。
一般时候,这样还可以用,但如图:
当:
1、字符串中出现纯英文或数字时,会导致输出不好看;
2、有时,中文字符还是会有半边缺失现象。。。
所以,请问,有什么更好办法使curses输出中文吗?
(ps:有人知道上面说的tqdm问题怎么处理也请告知一下,谢谢啦。。。
附图:)
可以试试 rich 里的 progress _2_ 发表于 2020-11-19 20:12
可以试试 rich 里的 progress
谢谢,但感觉和tqdm好像差不多,多线程同样会出现排列先后混乱情况
还是自己写着更切合。
你有解决上面文字问题的方法吗?
页:
[1]