1570ba320c style: 代码格式化和字符串处理优化
- 优化代码缩进和换行,提高可读性
- 统一使用单引号或双引号,保持一致性
- 移除冗余的空格和括号,精简代码
2025-02-15 21:30:24 +08:00

51 lines
1.5 KiB
Python

from source.expansion import Namespace
from .request import Html
__all__ = ["Image"]
class Image:
@classmethod
def get_image_link(cls, data: Namespace, format_: str) -> [list, list]:
images = data.safe_extract("imageList", [])
live_link = cls.__get_live_link(images)
token_list = [
cls.__extract_image_token(Namespace.object_extract(i, "urlDefault"))
for i in images
]
match format_:
case "png":
return [
Html.format_url(cls.__generate_png_link(i)) for i in token_list
], live_link
case "webp":
return [
Html.format_url(cls.__generate_webp_link(i)) for i in token_list
], live_link
case _:
raise ValueError
@staticmethod
def __generate_webp_link(token: str) -> str:
return f"https://sns-img-bd.xhscdn.com/{token}"
@staticmethod
def __generate_png_link(token: str) -> str:
return f"https://ci.xiaohongshu.com/{token}?imageView2/format/png"
@staticmethod
def __extract_image_token(url: str) -> str:
return "/".join(url.split("/")[5:]).split("!")[0]
@staticmethod
def __get_live_link(items: list) -> list:
return [
(
Html.format_url(
Namespace.object_extract(item, "stream.h264[0].masterUrl")
)
or None
)
for item in items
]