gpt4 book ai didi

python - 使用 utf-8 字符作为诅咒边框

转载 作者:行者123 更新时间:2023-12-04 13:16:08 26 4
gpt4 key购买 nike

我不能用 字符为诅咒边界。
代码示例:

import curses

stdscr = curses.initscr()
c = '█'
stdscr.border(c, c, c, c, c, c, c, c)
stdscr.getch()
我得到这个错误:

OverflowError: byte doesn't fit in chtype


但是我可以使用 addstr像这样写一些 utf-8 字符:
stdscr.addstr(0, 0, "█")
谢谢你的帮助。

最佳答案

问题在于 Python curses package 只是 ncurses C 库的包装器。在 ncurses ( https://linux.die.net/man/3/ncurses ) 中,字符表示为 chtype,(字符和属性数据),其中字符是 C char type 在普通系统上只是一个字节。

标的 border 函数期望边框的每个字符都是一个字节,而您尝试使用的“FULL BLOCK”是 unicode 字符 U+2588 或 UTF-8 字节字符串 b'\xe2\x96\x88' .这就是错误消息的原因:您尝试将 3 字节序列存储到单字节变量中。

它适用于 addstr因为该函数需要一个字符串并接受 3 个字节的序列。但它会打破 addch期望一个字符串。

换句话说,除了需要字符串的地方,curses 模块不会接受多字节 UTF-8 序列。

可能的解决方法:

  • 使用底层 ncurses 库和 curses 的推荐方法Python 模块是查找符合您要求的单字节编码。 Latin1 (ISO-8859-1) 甚至是 ncurses 的默认值,但其他编码可以更好地满足您的需求。
  • 找到(或编写)一个围绕 ncursesw 的 Python 包装器。这是使用宽(16 位)字符的 ncurses 的变体。它会很乐意接受0x2588作为字符值,或者更一般地说,任何只有 16 位代码点的字符,这只是 Unicode 的基本多语言平面。不幸的是,我不知道。
  • 关于python - 使用 utf-8 字符作为诅咒边框,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60350904/

    26 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com