2023-01-20 21:34:15 +08:00
|
|
|
|
from rich.console import Console
|
2023-01-27 23:25:28 +08:00
|
|
|
|
from exceptions import *
|
|
|
|
|
from typing import Any, Literal, Optional, TextIO
|
2023-01-20 21:34:15 +08:00
|
|
|
|
|
|
|
|
|
MainConsole = Console()
|
|
|
|
|
|
|
|
|
|
JustifyMethod = Literal["default", "left", "center", "right", "full"]
|
|
|
|
|
OverflowMethod = Literal["fold", "crop", "ellipsis", "ignore"]
|
|
|
|
|
|
2023-01-27 23:25:28 +08:00
|
|
|
|
|
2023-01-20 21:34:15 +08:00
|
|
|
|
# 高级的打印函数
|
|
|
|
|
def prt(
|
2023-01-28 11:56:09 +08:00
|
|
|
|
*objects: Any,
|
|
|
|
|
sep: str = " ",
|
|
|
|
|
end: str = "\n",
|
|
|
|
|
justify: Optional[JustifyMethod] = None,
|
|
|
|
|
overflow: Optional[OverflowMethod] = None,
|
|
|
|
|
no_wrap: Optional[bool] = None,
|
|
|
|
|
emoji: Optional[bool] = None,
|
|
|
|
|
markup: Optional[bool] = None,
|
|
|
|
|
highlight: Optional[bool] = None,
|
|
|
|
|
width: Optional[int] = None,
|
|
|
|
|
height: Optional[int] = None,
|
|
|
|
|
crop: bool = True,
|
|
|
|
|
soft_wrap: Optional[bool] = None,
|
|
|
|
|
new_line_start: bool = False,
|
2023-01-20 21:34:15 +08:00
|
|
|
|
) -> None:
|
|
|
|
|
"""打印到控制台。
|
|
|
|
|
|
|
|
|
|
Args:
|
|
|
|
|
objects (位置性的args): 要记录到终端的对象。
|
|
|
|
|
sep (str, 可选): 要在打印数据之间写入的字符串。默认为""。
|
|
|
|
|
end (str, optio可选nal): 在打印数据结束时写入的字符串。默认值为"\\\\n"。
|
|
|
|
|
justify (str, 可选): 校正位置,可为"default", "left", "right", "center" 或 "full". 默认为`None`。
|
|
|
|
|
overflow (str, 可选): 控制溢出:"ignore"忽略, "crop"裁剪, "fold"折叠, "ellipsis"省略号。默认为`None`。
|
|
|
|
|
no_wrap (Optional[bool], 可选): 禁用文字包装。默认为`None`。
|
|
|
|
|
emoji (Optional[bool], 可选): 启用表情符号代码,或使用控制台默认的`None`。默认为`None`。
|
|
|
|
|
markup (Optional[bool], 可选): 启用标记,或`None`使用控制台默认值。默认为`None`。
|
|
|
|
|
highlight (Optional[bool], 可选): 启用自动高亮,或`None`使用控制台默认值。默认为`None`。
|
|
|
|
|
width (Optional[int], 可选): 输出的宽度,或`None`自动检测。默认为`None`。
|
2023-01-27 23:25:28 +08:00
|
|
|
|
height
|
2023-01-20 21:34:15 +08:00
|
|
|
|
crop (Optional[bool], 可选): 裁剪输出到终端的宽度。默认为`True`。
|
|
|
|
|
soft_wrap (bool, 可选): 启用软包装模式,禁止文字包装和裁剪,或`None``用于 控制台默认值。默认为`None`。
|
|
|
|
|
new_line_start (bool, False): 如果输出包含多行,在开始时插入一个新行。默认值为`False`。
|
|
|
|
|
"""
|
|
|
|
|
MainConsole.print(
|
|
|
|
|
*objects,
|
|
|
|
|
sep=sep,
|
|
|
|
|
end=end,
|
|
|
|
|
style="#F0F2F4 on #121110",
|
|
|
|
|
justify=justify,
|
|
|
|
|
overflow=overflow,
|
|
|
|
|
no_wrap=no_wrap,
|
|
|
|
|
emoji=emoji,
|
|
|
|
|
markup=markup,
|
|
|
|
|
highlight=highlight,
|
|
|
|
|
width=width,
|
|
|
|
|
height=height,
|
|
|
|
|
crop=crop,
|
|
|
|
|
soft_wrap=soft_wrap,
|
|
|
|
|
new_line_start=new_line_start,
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# 高级的输入函数
|
|
|
|
|
def ipt(
|
2023-01-28 11:56:09 +08:00
|
|
|
|
*objects: Any,
|
|
|
|
|
sep: str = " ",
|
|
|
|
|
justify: Optional[JustifyMethod] = None,
|
|
|
|
|
overflow: Optional[OverflowMethod] = None,
|
|
|
|
|
no_wrap: Optional[bool] = None,
|
|
|
|
|
emoji: Optional[bool] = None,
|
|
|
|
|
markup: Optional[bool] = None,
|
|
|
|
|
highlight: Optional[bool] = None,
|
|
|
|
|
width: Optional[int] = None,
|
|
|
|
|
height: Optional[int] = None,
|
|
|
|
|
crop: bool = True,
|
|
|
|
|
soft_wrap: Optional[bool] = None,
|
|
|
|
|
new_line_start: bool = False,
|
|
|
|
|
password: bool = False,
|
|
|
|
|
stream: Optional[TextIO] = None,
|
2023-01-20 21:34:15 +08:00
|
|
|
|
) -> str:
|
|
|
|
|
"""显示一个提示并等待用户的输入。
|
|
|
|
|
|
|
|
|
|
它的工作方式与Python内建的 :func:`input` 函数相同,如果Python内建的 :mod:`readline` 模块先前已经加载,则提供详细的行编辑和历史功能。
|
|
|
|
|
|
|
|
|
|
Args:
|
|
|
|
|
objects (位置性的args): 要记录到终端的对象。
|
|
|
|
|
sep (str, 可选): 要在打印数据之间写入的字符串。默认为""。
|
|
|
|
|
justify (str, 可选): 校正位置,可为"default", "left", "right", "center" 或 "full". 默认为`None`。
|
|
|
|
|
overflow (str, 可选): 控制溢出:"ignore"忽略, "crop"裁剪, "fold"折叠, "ellipsis"省略号。默认为`None`。
|
|
|
|
|
no_wrap (Optional[bool], 可选): 禁用文字包装。默认为`None`。
|
|
|
|
|
emoji (Optional[bool], 可选): 启用表情符号代码,或使用控制台默认的`None`。默认为`None`。
|
|
|
|
|
markup (Optional[bool], 可选): 启用标记,或`None`使用控制台默认值。默认为`None`。
|
|
|
|
|
highlight (Optional[bool], 可选): 启用自动高亮,或`None`使用控制台默认值。默认为`None`。
|
|
|
|
|
width (Optional[int], 可选): 输出的宽度,或`None`自动检测。默认为`None`。
|
|
|
|
|
crop (Optional[bool], 可选): 裁剪输出到终端的宽度。默认为`True`。
|
2023-01-27 23:25:28 +08:00
|
|
|
|
height
|
2023-01-20 21:34:15 +08:00
|
|
|
|
soft_wrap (bool, 可选): 启用软包装模式,禁止文字包装和裁剪,或`None``用于 控制台默认值。默认为`None`。
|
|
|
|
|
new_line_start (bool, False): 如果输出包含多行,在开始时插入一个新行。默认值为`False`。
|
|
|
|
|
password (bool, 可选): 隐藏已经输入的文案,默认值为`False`。
|
|
|
|
|
stream (TextIO, 可选): 可选从文件中读取(而非控制台),默认为 `None`。
|
|
|
|
|
|
|
|
|
|
Returns:
|
|
|
|
|
str: 从stdin读取的字符串
|
|
|
|
|
"""
|
|
|
|
|
MainConsole.print(
|
|
|
|
|
*objects,
|
|
|
|
|
sep=sep,
|
|
|
|
|
end="",
|
|
|
|
|
style="#F0F2F4 on #121110",
|
|
|
|
|
justify=justify,
|
|
|
|
|
overflow=overflow,
|
|
|
|
|
no_wrap=no_wrap,
|
|
|
|
|
emoji=emoji,
|
|
|
|
|
markup=markup,
|
|
|
|
|
highlight=highlight,
|
|
|
|
|
width=width,
|
|
|
|
|
height=height,
|
|
|
|
|
crop=crop,
|
|
|
|
|
soft_wrap=soft_wrap,
|
|
|
|
|
new_line_start=new_line_start,
|
|
|
|
|
)
|
|
|
|
|
|
2023-01-27 23:25:28 +08:00
|
|
|
|
return MainConsole.input(password=password, stream=stream)
|
2023-01-20 21:34:15 +08:00
|
|
|
|
|
|
|
|
|
|
2023-01-27 23:25:28 +08:00
|
|
|
|
def format_ipt(
|
2023-01-28 11:56:09 +08:00
|
|
|
|
notice: str,
|
|
|
|
|
fun,
|
|
|
|
|
err_note: str = "",
|
|
|
|
|
*extraArg,
|
2023-01-20 21:34:15 +08:00
|
|
|
|
):
|
2023-01-27 23:25:28 +08:00
|
|
|
|
"""循环输入,以某种格式
|
2023-01-20 21:34:15 +08:00
|
|
|
|
notice: 输入时的提示
|
|
|
|
|
fun: 格式函数
|
2023-01-27 23:25:28 +08:00
|
|
|
|
err_note: 输入不符格式时的提示
|
|
|
|
|
*extraArg: 对于函数的其他参数"""
|
2023-01-20 21:34:15 +08:00
|
|
|
|
while True:
|
|
|
|
|
result = ipt(notice)
|
|
|
|
|
try:
|
2023-01-27 23:25:28 +08:00
|
|
|
|
fun_result = fun(result, *extraArg)
|
2023-01-20 21:34:15 +08:00
|
|
|
|
break
|
2023-01-27 23:25:28 +08:00
|
|
|
|
except BaseError:
|
|
|
|
|
prt(err_note)
|
2023-01-20 21:34:15 +08:00
|
|
|
|
continue
|
2023-01-27 23:25:28 +08:00
|
|
|
|
return result, fun_result
|