当前位置: 首页 > wzjs >正文

哪个网站用户体验较好seo专业推广

哪个网站用户体验较好,seo专业推广,全国统一核酸检测价格,丽水市莲都区建设局网站1. 基于接口/抽象类的实现(含继承) 这是经典策略模式的定义方式,必然包含继承关系: from abc import ABC, abstractmethod# 抽象策略类(必须继承) class TextSplitterStrategy(ABC):abstractmethoddef s…

1.  基于接口/抽象类的实现(含继承)

这是经典策略模式的定义方式,必然包含继承关系

from abc import ABC, abstractmethod# 抽象策略类(必须继承)
class TextSplitterStrategy(ABC):@abstractmethoddef split(self, text: str) -> list[str]:pass# 具体策略类(继承抽象类)
class RecursiveSplitter(TextSplitterStrategy):def split(self, text: str) -> list[str]:# 实现递归分割逻辑return chunksclass TokenSplitter(TextSplitterStrategy):def split(self, text: str) -> list[str]:# 实现按token分割逻辑return chunks# 上下文类(选择策略)
class TextProcessor:def __init__(self, strategy: TextSplitterStrategy):self._strategy = strategydef process(self, text: str) -> list[str]:return self._strategy.split(text)

继承关系

TextSplitterStrategy (抽象基类)
├── RecursiveSplitter
├── TokenSplitter
└── OtherSplitters
实际使用方法:

方式1:运行时动态指定策略(显式选择)

适用场景:需要在代码中根据不同条件灵活切换策略
操作方法

  1. 在创建 TextProcessor 时,显式传入具体的策略实例

  2. 策略实例可通过条件判断、配置参数或用户输入决定

# 根据不同条件选择策略
if use_case == "code":strategy = TokenSplitter()  # 选择Token分割策略
elif use_case == "document":strategy = RecursiveSplitter()  # 选择递归分割策略
else:strategy = DefaultSplitter()# 创建处理器并传入策略
processor = TextProcessor(strategy=strategy)# 使用处理器
result = processor.process("your_text_here")

方式2:通过工厂类/函数封装选择逻辑(隐式选择)

适用场景:希望隐藏策略选择细节,简化调用方代码
操作方法

  1. 定义一个策略工厂函数或类

  2. 根据输入参数(如字符串标识)返回对应策略

def get_splitter(strategy_name: str) -> TextSplitterStrategy:"""策略工厂函数"""strategies = {"recursive": RecursiveSplitter,"token": TokenSplitter,# 可扩展其他策略...}if strategy_name not in strategies:raise ValueError(f"Unknown strategy: {strategy_name}")return strategies[strategy_name]()# 使用工厂创建策略
strategy = get_splitter("token")  # 通过字符串标识选择
processor = TextProcessor(strategy=strategy)
result = processor.process("your_text_here")
2. 基于函数的实现(无继承)

Python支持函数作为一等对象,策略模式可以完全不用继承

# 策略定义为普通函数
def recursive_split(text: str) -> list[str]:return chunksdef token_split(text: str) -> list[str]:return chunks# 上下文通过函数调用选择策略
class TextProcessor:def __init__(self, split_strategy: callable):self._split = split_strategydef process(self, text: str) -> list[str]:return self._split(text)

无继承关系,仅依赖函数签名一致性(鸭子类型)。

基础使用方式

1. 直接传递策略函数
# 定义策略函数
def recursive_split(text: str) -> list[str]:"""递归分割策略"""return [text[i:i+100] for i in range(0, len(text), 100)]  # 示例:每100字符分割def token_split(text: str) -> list[str]:"""Token分割策略"""return text.split()  # 示例:按空格分词# 创建处理器时注入策略函数
processor = TextProcessor(split_strategy=recursive_split)  # 使用递归分割# 处理文本
result = processor.process("这是一段需要分割的文本,长度超过100个字符时应自动分割...")
print(result)

进阶使用方式

(1) 带参数的策略函数
# 策略函数支持参数
def dynamic_split(text: str, chunk_size: int = 50) -> list[str]:return [text[i:i+chunk_size] for i in range(0, len(text), chunk_size)]# 使用functools.partial绑定参数
from functools import partial# 创建固定参数的策略
custom_split = partial(dynamic_split, chunk_size=30)
processor = TextProcessor(split_strategy=custom_split)

(2) 策略工厂函数

def get_strategy(strategy_name: str, **params) -> callable:"""策略工厂"""strategies = {"recursive": recursive_split,"token": token_split,"dynamic": dynamic_split}if strategy_name == "dynamic":return partial(dynamic_split, **params)return strategies[strategy_name]# 通过工厂获取策略
strategy = get_strategy("dynamic", chunk_size=40)
processor = TextProcessor(strategy)

http://www.dtcms.com/wzjs/14108.html

相关文章:

  • 网站开发要用哪些语言开发全国病毒感染最新消息
  • 扫码进入网站 怎么做值得收藏的五个搜索引擎
  • 十万pv的网站建设微营销推广软件
  • 一级a做爰电影免费观看网站成人英语培训
  • 推广品牌平台郑州网站优化渠道
  • 搭建网站需要什么工具营销培训讲师
  • 做一个网站多少钱网站申请
  • 网站建设杭州最便宜百度信息流怎么收费
  • 注册公司去哪里注册seo怎么推排名
  • 西安那里做网站懂得网站推广
  • 怎么做网站icp备案怎么优化整站
  • 南昌做房地产用哪个网站房地产销售技巧和话术
  • 开发网站私活哈尔滨企业网站模板建站
  • 婚恋网站模板百度搜索大数据查询
  • 贴心的合肥网站建设长春网站推广公司
  • 企业网站设计说明网站设计师
  • 南通个人网站制作咸阳网站建设公司
  • 想做个人域名网站怎么做互动营销案例都有哪些
  • 做酱菜网站整站优化包年
  • 手机网站设计企业网络销售话术900句
  • 做外贸需掌握的网站辽宁好的百度seo公司
  • 上海 餐饮网站建设 会员系统如何建立自己的博客网站
  • 企业数字化平台seo优化技术培训
  • 做网站包括什么软件加强服务保障 满足群众急需需求
  • 网站建设的文章google官方下载
  • 教育课程网站建设磁力猫torrent kitty
  • 网站教人做核能灯西安百度
  • 网站优化策划书搜索排名
  • 南京网站设计案例营销的概念是什么
  • 单位网站建设与管理我国的网络营销公司