LiteyukiBot-TriM/liteyuki/utils/tools.py

75 lines
1.8 KiB
Python
Raw Normal View History

2024-03-24 09:43:34 +08:00
from importlib.metadata import PackageNotFoundError, version
2024-04-03 01:03:25 +08:00
def clamp(value: float, min_value: float, max_value: float) -> float | int:
"""将值限制在最小值和最大值之间
Args:
value (float): 要限制的值
min_value (float): 最小值
max_value (float): 最大值
Returns:
float: 限制后的值
"""
return max(min(value, max_value), min_value)
2024-04-05 07:02:18 +08:00
def convert_size(size: int, precision: int = 2, add_unit: bool = True, suffix: str = " XiB") -> str | float:
2024-03-19 13:16:25 +08:00
"""把字节数转换为人类可读的字符串,计算正负
Args:
add_unit: 是否添加单位False后则suffix无效
2024-04-05 07:02:18 +08:00
suffix: XiB或XB
2024-03-19 13:16:25 +08:00
precision: 浮点数的小数点位数
size (int): 字节数
Returns:
str: The human-readable string, e.g. "1.23 GB".
"""
2024-04-05 07:02:18 +08:00
is_negative = size < 0
size = abs(size)
for unit in ("", "K", "M", "G", "T", "P", "E", "Z"):
2024-03-19 13:16:25 +08:00
if size < 1024:
2024-04-05 07:02:18 +08:00
break
2024-03-19 13:16:25 +08:00
size /= 1024
2024-04-05 07:02:18 +08:00
if is_negative:
size = -size
2024-03-19 13:16:25 +08:00
if add_unit:
2024-04-05 07:02:18 +08:00
return f"{size:.{precision}f}{suffix.replace('X', unit)}"
2024-03-19 13:16:25 +08:00
else:
2024-04-05 07:02:18 +08:00
return size
def keywords_in_text(keywords: list[str], text: str, all_matched: bool) -> bool:
"""
检查关键词是否在文本中
Args:
keywords: 关键词列表
text: 文本
all_matched: 是否需要全部匹配
Returns:
"""
if all_matched:
for keyword in keywords:
if keyword not in text:
return False
return True
else:
for keyword in keywords:
if keyword in text:
return True
return False
2024-03-24 09:43:34 +08:00
def check_for_package(package_name: str) -> bool:
try:
version(package_name)
return True
except PackageNotFoundError:
return False