python 自动注册模式

自动注册模式

通过自动注册模式,减少if-else使得逻辑更清晰。

代码

python 复制代码
import inspect
import sys
from typing import Any, Dict, Callable,List
from datetime import datetime


def message_handler(msg_type: str, priority: int = 0):
    def decorator(func: Callable) -> Callable:
        func.handle_type = msg_type
        func.priority = priority
        return func

    return decorator


def auto_register_handlers(module):
    handlers = {}
    for name, obj in inspect.getmembers(module):
        if inspect.isfunction(obj) and hasattr(obj, "handle_type"):
            msg_type = obj.handle_type
            if msg_type not in handlers:
                handlers[msg_type] = []
            handlers[msg_type].append(obj)
            # 按优先级排序
            handlers[msg_type].sort(key=lambda x: getattr(x, "priority", 0), reverse=True)
    return handlers


class MessageContext:
    def __init__(self,msg_type: str, content: Any, sender: str, timestamp: datetime):
        self.msg_type = msg_type
        self.content = content
        self.sender = sender
        self.timestamp = timestamp


# 定义各种消息处理器
@message_handler("text")
def handle_text(ctx: MessageContext) -> str:
    return f"[文本消息] {ctx.sender}: {ctx.content}"

@message_handler("image", priority=1)
def handle_image(ctx: MessageContext) -> str:
    return f"[图片消息] {ctx.sender} 分享了图片: {ctx.content}"

@message_handler("image")
def handle_image_like(ctx: MessageContext) -> str:
    return f"并且在{ctx.timestamp.strftime('%Y-%m-%d %H:%M')}获得了一个点赞。"

@message_handler("location")
def handle_location(ctx: MessageContext) -> str:
    return f"[位置消息] {ctx.sender} 分享了位置: {ctx.content}"


class ChatSystem:
    def __init__(self):
        self.handlers: Dict[str, List[Callable]] = auto_register_handlers(sys.modules[__name__])
        self.middlewares = []
        self.message_log = []

    def add_middleware(self, middleware):
        self.middlewares.append(middleware)

    def process_message(self, msg_type: str, content: Any, sender: str) -> str:
        context = MessageContext(msg_type, content, sender, datetime.now())

        # 执行中间件
        for middleware in self.middlewares:
            if not middleware.before_process(context):
                return f"{context.content}消息被中间件拦截"

        # 处理消息
        result = self._process_message(msg_type, context)

        # 后置中间件处理
        for middleware in reversed(self.middlewares):
            result = middleware.after_process(result, context)

        return result

    def _process_message(self, msg_type: str, context: MessageContext) -> str:
        handler = self.handlers.get(msg_type)
        if handler:
            result = [h(context) for h in handler]
            self.message_log.append((msg_type, context))
            return ", ".join(result)
        return f"不支持的消息类型:{msg_type}"


# 定义日志中间件
class LoggingMiddleware:
    def before_process(self, context):
        print(f"收到来自 {context.sender} 的消息")
        return True

    def after_process(self, result, context):
        print(f"消息处理完成: {result}")
        return result


# 定义敏感词过滤中间件
class SensitiveWordMiddleware:
    def __init__(self, sensitive_words):
        self.sensitive_words = sensitive_words

    def before_process(self, context):
        if isinstance(context.content, str):
            for word in self.sensitive_words:
                if word in context.content:
                    return False
        return True

    def after_process(self, result, context):
        return result


# 使用示例
if __name__ == "__main__":
    chat_system = ChatSystem()

    # 添加中间件
    chat_system.add_middleware(LoggingMiddleware())
    chat_system.add_middleware(SensitiveWordMiddleware(["敏感词1", "敏感词2"]))

    # 处理消息
    messages = [
        ("text", "你好,世界!", "张三"),
        ("image", "风景照片.jpg", "李四"),
        ("location", "北京市海淀区", "王五"),
        ("video", "视频文件.mp4", "赵六"),
        ("image", "敏感词1.jpg", "钱七"),
    ]

    for msg_type, content, sender in messages:
        result = chat_system.process_message(msg_type, content, sender)
        print(f"结果: {result}\n")
相关推荐
Boilermaker199213 小时前
[Java 并发编程] Synchronized 锁升级
java·开发语言
沈浩(种子思维作者)13 小时前
真的能精准医疗吗?癌症能提前发现吗?
人工智能·python·网络安全·健康医疗·量子计算
MM_MS13 小时前
Halcon变量控制类型、数据类型转换、字符串格式化、元组操作
开发语言·人工智能·深度学习·算法·目标检测·计算机视觉·视觉检测
꧁Q༒ོγ꧂14 小时前
LaTeX 语法入门指南
开发语言·latex
njsgcs14 小时前
ue python二次开发启动教程+ 导入fbx到指定文件夹
开发语言·python·unreal engine·ue
alonewolf_9914 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
io_T_T14 小时前
迭代器 iteration、iter 与 多线程 concurrent 交叉实践(详细)
python
古城小栈14 小时前
Rust 迭代器产出的引用层数——分水岭
开发语言·rust
华研前沿标杆游学14 小时前
2026年走进洛阳格力工厂参观游学
python
Carl_奕然14 小时前
【数据挖掘】数据挖掘必会技能之:A/B测试
人工智能·python·数据挖掘·数据分析