python 实用工具状态机transitions


Posted in Python onNovember 21, 2020

说明 

1. 状态机是一个非常实用的理论。在涉及到复杂的场景,建立状态机模型,能带来极大的方便。比如,网络连接、模型状态、业务逻辑。 
2. 状态机并不复杂, 重要的是它的思想,能够极大减轻复杂度。使用时关键在于定义好事件和动作。 

基本概念 

  • State: 状态
  • Event: 事件. 事件触发状态变换
  • Action: 动作. event发生前或后执行的动作
  • transition: 变换. 状态变换

github

https://github.com/pytransitions/transitions

安装

pip install transitions

简单示例

# 连接协议状态机
from transitions.extensions import HierarchicalMachine as Machine
from transitions.extensions.nesting import NestedState
 
class ConnectionStateMachine:
    """Connection state machine."""
 
    def __init__(self, callbacks=None):
        """
        :param callbacks: callbacks for the state machine
        """
        self.callbacks = {}
 
        # 定义状态
        self.states = ["STATE_NOT_CONNECTED",
                       {
                            'name': "STATE_CONNECTED",   # 状态名
                            'on_enter': self._on_enter_CONNECTED,  # 进入状态触发
                            'on_exit': self._on_exit_CONNECTED,    # 退出状态触发
                            'children': [     # 状态嵌套
                                "STATE_NOT_SELECTED",
                                {
                                    'name': "STATE_SELECTED",
                                    'on_enter': self._on_enter_CONNECTED_SELECTED
                                }
                            ]
                       }]
 
        # transition 1
        self.machine = Machine(model=self, states=self.states, initial="STATE_NOT_CONNECTED", auto_transitions=False)
 
        if callbacks:
            self.callbacks = callbacks
 
        # 定义状态变换
        self.machine.add_transition('connect', "STATE_NOT_CONNECTED", "STATE_CONNECTED_NOT_SELECTED")  # transition 2
        self.machine.add_transition('disconnect', "STATE_CONNECTED", "STATE_NOT_CONNECTED")  # transition 3
        self.machine.add_transition('select', "STATE_CONNECTED_NOT_SELECTED", "STATE_CONNECTED_SELECTED")  # transition 4
        self.machine.add_transition('deselect', "STATE_CONNECTED_SELECTED", "STATE_CONNECTED_NOT_SELECTED")  # transition 5
        self.machine.add_transition('timeoutT7', "STATE_CONNECTED_NOT_SELECTED", "STATE_NOT_CONNECTED")  # transition 6
 
    # 事件触发的动作
    def _on_enter_CONNECTED(self):
        if "on_enter_CONNECTED" in self.callbacks:
            self.callbacks["on_enter_CONNECTED"]()
 
    def _on_exit_CONNECTED(self):
        if "on_exit_CONNECTED" in self.callbacks:
            self.callbacks["on_exit_CONNECTED"]()
 
    def _on_enter_CONNECTED_SELECTED(self):
        if "on_enter_CONNECTED_SELECTED" in self.callbacks:
            self.callbacks["on_enter_CONNECTED_SELECTED"]()

定义状态机

# 一般都是两种:不嵌套、嵌套
from transitions import Machine   #不嵌套
from transitions.extensions import HierarchicalMachine as Machine # 嵌套
 
# 检查状态
machine.state
machine.is_<state_name>()

定义状态

# 状态可以是三种类型: 对象、字符串、字典
from transitions import State
states = [
    State(name="solid"),    # 对象
    "liquid",               # 字符串
    {"name": "gas"}         # 字典
]

定义变换

# 定义函数
machine.add_transition(trigger, source, dest, )
trigger(str)         方法名,触发状态转换
source(str or list)  源状态
dest(str)            目标状态
 
# 加上变换
machine.add_transition(trigger="wake_up", source="asleep", dest="hanging out")
machine.add_transition('work_out', 'hanging out', 'hungry')
machine.add_transition('nap', '*', 'asleep')   # 从任意状态变为asleep

以上就是python 实用工具状态机transitions的详细内容,更多关于python transitions的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python实现将SQLite中的数据直接输出为CVS的方法示例
Jul 13 Python
Django 前后台的数据传递的方法
Aug 08 Python
解决python爬虫中有中文的url问题
May 11 Python
python利用插值法对折线进行平滑曲线处理
Dec 25 Python
Python 3.3实现计算两个日期间隔秒数/天数的方法示例
Jan 07 Python
python变量赋值方法(可变与不可变)
Jan 12 Python
Django基础知识 URL路由系统详解
Jul 18 Python
使用Django搭建web服务器的例子(最最正确的方式)
Aug 29 Python
用python解压分析jar包实例
Jan 16 Python
使用python批量转换文件编码为UTF-8的实现
Apr 03 Python
Python+Selenium随机生成手机验证码并检查页面上是否弹出重复手机号码提示框
Sep 21 Python
使paramiko库执行命令时在给定的时间强制退出功能的实现
Mar 03 Python
python 实现表情识别
Nov 21 #Python
python 实现性别识别
Nov 21 #Python
python遍历路径破解表单的示例
Nov 21 #Python
Python如何批量生成和调用变量
Nov 21 #Python
在终端启动Python时报错的解决方案
Nov 20 #Python
python 批量下载bilibili视频的gui程序
Nov 20 #Python
Python ellipsis 的用法详解
Nov 20 #Python
You might like
《Pokemon Sword·Shield》系列WEB动画《薄明之翼》第2话声优阵容公开!
2020/03/06 日漫
让你的WINDOWS同时支持MYSQL4,MYSQL4.1,MYSQL5X
2006/12/06 PHP
php中的一些数组排序方法分享
2012/07/20 PHP
PHP中使用Imagick实现各种图片效果实例
2015/01/21 PHP
php使用ZipArchive函数实现文件的压缩与解压缩
2015/10/27 PHP
PHP如何实现跨域
2016/05/30 PHP
laravel批量生成假数据的方法
2019/10/09 PHP
使用TextRange获取输入框中光标的位
2006/10/14 Javascript
javascript document.execCommand() 常用解析
2009/12/14 Javascript
js 获取屏幕各种宽高的方法(浏览器兼容)
2013/05/15 Javascript
JS中操作JSON总结
2020/12/06 Javascript
js网页右下角提示框实例
2014/10/14 Javascript
详细解读JavaScript的跨浏览器事件处理
2015/08/12 Javascript
ES6新特性之函数的扩展实例详解
2017/04/01 Javascript
大白话讲解JavaScript的Promise
2017/04/06 Javascript
JQuery form表单提交前验证单选框是否选中、删除记录时验证经验总结(整理)
2017/06/09 jQuery
Web开发使用Angular实现用户密码强度判别的方法
2017/09/27 Javascript
JQuery 又谈ajax局部刷新
2017/11/27 jQuery
微信小程序使用toast消息对话框提示用户忘记输入用户名或密码功能【附源码下载】
2017/12/09 Javascript
详解VueJs中的V-bind指令
2018/05/03 Javascript
layui动态表头的实现代码
2019/08/22 Javascript
浅谈Three.js截图并下载的大坑
2019/11/01 Javascript
python修改操作系统时间的方法
2015/05/18 Python
Python实现的RSS阅读器实例
2015/07/25 Python
python实现将内容分行输出
2015/11/05 Python
Python中Scrapy爬虫图片处理详解
2017/11/29 Python
深入理解python中sort()与sorted()的区别
2018/08/29 Python
python GUI库图形界面开发之PyQt5中QWebEngineView内嵌网页与Python的数据交互传参详细方法实例
2020/02/26 Python
GDAL 矢量属性数据修改方式(python)
2020/03/10 Python
美国领先的家庭健康检测试剂盒提供商:LetsGetChecked
2019/03/18 全球购物
日本动漫周边服饰销售网站:Atsuko
2019/12/16 全球购物
学生打架检讨书大全
2014/01/23 职场文书
旅游文化节策划方案
2014/06/06 职场文书
金秋助学感谢信
2015/01/21 职场文书
2015最新民情日记范文
2015/06/26 职场文书
大学生学习十八届五中全会精神心得体会
2016/01/05 职场文书