Python 实现接口类的两种方式+邮件提醒+动态导入模块+反射(参考Django中间件源码)

实现抽象类的两种方式

方式一

复制代码
from abc import ABCMeta
from abc import abstractmethod
 
class BaseMessage(metaclass=ABCMeta):
 
    @abstractmethod
    def send(self,subject,body,to,name):
        pass

方式二

复制代码
class BaseMessage(object):
    def send(self, subject, body, to, name):
        raise NotImplementedError('未实现send方法')

邮件提醒

复制代码
import smtplib
from email.mime.text import MIMEText
from email.utils import formataddr
from .base import BaseMessage
 
class Email(BaseMessage):
    def __init__(self):
        self.email = "寄件人的邮箱地址"
        self.user = "寄件人姓名"
        self.pwd = '邮箱密码或SMTP授权码'
 
    def send(self,subject,body,to,name):
        '''
        :param subject: 主题
        :param body: 内容
        :param to:接受者
        :param name:接受者姓名
        :return:
        '''
 
        msg = MIMEText(body, 'plain', 'utf-8')  # 发送内容
        msg['From'] = formataddr([self.user,self.email])  # 发件人
        msg['To'] = formataddr([name, to])  # 收件人
        msg['Subject'] = subject # 主题
 
        server = smtplib.SMTP("smtp.126.com", 25) # SMTP服务
        server.login(self.email, self.pwd) # 邮箱用户名和密码
        server.sendmail(self.email, [to, ], msg.as_string()) # 发送者和接收者
        server.quit()

动态导入模块+反射

settings

复制代码
# ################## 自定义消息提醒的配置 ###################
MESSAGE_CLASSES = [
    'utils.message.email.Email',
    'utils.message.msg.Msg',
    'utils.message.wx.WeChat',
    'utils.message.dingding.DingDing',
]

import importlib
from django.conf import settings
def send_message(to,name,subject,body):
    """
    短信、邮件、微信
    :param to: 接受者
    :param name: 接受者姓名
    :param subject: 主题
    :param body: 内容
    :return:
    """
    for cls_path in settings.MESSAGE_CLASSES:
        # cls_path是字符串
        module_path,class_name = cls_path.rsplit('.',maxsplit=1)  # 得到模块名的地址和模块里的一个类名(都是字符串)
        m = importlib.import_module(module_path)  # 导入模块
        obj = getattr(m,class_name)()·# 通过反射,得到字符串class_name对应的类,并实例化
        obj.send(subject,body,to,name,)  # 执行对应的send方法
相关推荐
小短腿的代码世界12 小时前
从.qrc到rcc编译器:Qt资源系统的隐秘运作机制与大型项目性能突围
开发语言·qt
MY_TEUCK12 小时前
【2026最新Python+AI学习基础】Python 入门笔记篇
笔记·python·学习
2401_8332693012 小时前
Java网络编程入门
java·开发语言
青瓦梦滋12 小时前
C++的IO流与STL的空间配置器
开发语言·c++
赢乐12 小时前
大模型学习笔记:检索增强生成(RAG)架构
人工智能·python·深度学习·机器学习·智能体·幻觉·检索增强生成(rag)
五月君_13 小时前
Bun v1.3.14 发布,Rust 版即将进 Claude Code 内测,下一版可能就告别 Zig
开发语言·后端·rust
鱼很腾apoc14 小时前
【学习篇】第20期 超详解 C++ 多态:从语法规则到底层原理
java·c语言·开发语言·c++·学习·算法·青少年编程
浪里行舟14 小时前
你的品牌正在被AI“遗忘”?用BuildSOM找回搜索的下一个风口
人工智能·python·程序员
不吃土豆的马铃薯15 小时前
4.SGI STL 二级空间配置器 allocate 与_S_refill 源码解析
c语言·开发语言·c++·dreamweaver·内存池
码界筑梦坊15 小时前
120-基于Python的食品营养特征数据可视化分析系统
开发语言·python·信息可视化·数据分析·毕业设计·echarts·fastapi