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

武夷山网站制作seo顾问培训

武夷山网站制作,seo顾问培训,网站还没有做解析是什么意思,免费网站建设报价rule-engine是一种轻量级、可选类型的表达式语言,具有用于匹配任意 Python 对象的自定义语法,使用python语言开发。 规则引擎表达式用自己的语言编写,在 Python 中定义为字符串。其语法与 Python 最相似,但也受到 Ruby 的一些启发…

rule-engine是一种轻量级、可选类型的表达式语言,具有用于匹配任意 Python 对象的自定义语法,使用python语言开发。

规则引擎表达式用自己的语言编写,在 Python 中定义为字符串。其语法与 Python 最相似,但也受到 Ruby 的一些启发。这种语言的一些特性包括:

  • 可选类型提示
  • 用正则表达式匹配字符串
  • 日期时间数据类型
  • 复合数据类型(相当于 Python 字典、列表和集合类型)
  • 数据属性
  • 线程安全

参考文档可在 https://zeroSteiner.github.io/rule-engine/ 获取。

规则语法

创建规则的语法基于计算为 True(匹配)或 False(不匹配)的逻辑表达式。规则支持一小组数据类型,这些数据类型可以定义为文字或使用应用规则的 Python 对象进行解析。有关受支持类型的完整列表,请参阅数据类型表。

并非所有受支持的操作都适用于下表所示的所有数据类型。规则遵循标准的操作顺序。

语法

表达式语法支持多种操作,包括数值数据的基本算术和字符串的正则表达式。操作是类型感知的,并且在使用不兼容的类型时会引发异常。

支持的操作

下表概述了可在规则引擎表达式中使用的所有运算符。

算术运算符

在这里插入图片描述

比较运算符

在这里插入图片描述

算术比较运算符

在这里插入图片描述

逻辑运算符

在这里插入图片描述

  • 按位运算支持浮点值,但如果该值不是自然数,则会引发EvaluationError。

  • 算术比较运算符支持多种数据类型,但左值的数据类型必须与右值的数据类型相同。例如,一个 STRING 可以与另一个 STRING 进行比较,但不能与 FLOAT 进行比较。该技术与 Python 使用的基于字典顺序的序列比较技术相同。

  • 使用正则表达式操作时,左侧的表达式是要比较的字符串,右侧的表达式是用于匹配或搜索操作的正则表达式。

关于时间 DATETIME 值

DATETIME 文字必须以 ISO-8601 格式指定。底层解析逻辑由 dateutil.parser.isoparse() 提供。未指定时间的 DATETIME 值(例如 d"2019-09-23")将计算为指定日期的午夜整点的 DATETIME。

显示等效文字表达式的示例规则:

d"2019-09-23" == d"2019-09-23 00:00:00" (日期默认为午夜,除非指定时间)

安装

pip install -i https://pypi.tuna.tsinghua.edu.cn/simple rule-engine

示例代码

示例1,官方示例

import rule_engine
# match a literal first name and applying a regex to the email
rule = rule_engine.Rule('first_name == "Luke" and email =~ ".*@rebels.org$"'
) # => <Rule text='first_name == "Luke" and email =~ ".*@rebels.org$"' >
rule.matches({'first_name': 'Luke', 'last_name': 'Skywalker', 'email': 'luke@rebels.org'
}) # => True
rule.matches({'first_name': 'Darth', 'last_name': 'Vader', 'email': 'dvader@empire.net'
}) # => False

示例2,自定义

在这里插入图片描述

rule = rule_engine.Rule('num >= 20000 and num<=30000'
)
rule.matches({'num': 2500
}) # Truerule = rule_engine.Rule('(num >= 2000 and num<=3000) or type=="cars"'
)
rule.matches({'num': 1500,'type':'bus'
})  # False

示例3,过滤

改造此方法,可以实现示例2中,按条件获取得分值。

import datetimecomics = [{'title': 'Batman','publisher': 'DC','issue': 89,'released': datetime.date(2020, 4, 28)},{'title': 'Flash','publisher': 'DC','issue': 753,'released': datetime.date(2020, 5, 5)},{'title': 'Captain Marvel','publisher': 'Marvel','issue': 18,'released': datetime.date(2020, 5, 6)}
]
rule = rule_engine.Rule(# match books published by DC'publisher == "DC"'
)
for v in rule.filter(comics):print(v)print(v['title'])
	{'title': 'Batman', 'publisher': 'DC', 'issue': 89, 'released': datetime.date(2020, 4, 28)}Batman{'title': 'Flash', 'publisher': 'DC', 'issue': 753, 'released': datetime.date(2020, 5, 5)}Flash

示例4,另外一种方案

conditon=[['num >= 30000',40],['num >= 20000 and num<30000',30],['num >= 10000 and num<20000',20],['num <10000',10]]num = 13003
for v in conditon:rule=rule_engine.Rule(v[0])if rule.matches({'num':num}):print(v[1])break

总结

rule-engine做为一种轻量级规则引擎,在数据分析中做为条件规则使用,基本够用了。

参考:

Considerations for building a rules engine in Python. 2021.09
https://zerosteiner.github.io/rule-engine/index.html

http://www.15wanjia.com/news/51501.html

相关文章:

  • ppt做杂志模板下载网站seo搜索引擎优化教程
  • 有什么平面设计的网站百度视频排名优化
  • 网站 运营 外包 每个月多少钱手机优化什么意思
  • 有什么网站可以做浏览单公司做网站怎么做
  • 怎么把网站建设推广出去长春网站建设公司
  • 鞍山信息港二手房出租seo文章是什么意思
  • 律师行业网站模板如何制作个人网站
  • 宜春代做网站河南郑州做网站的公司
  • 做市场浏览什么网站关键词查询网站的工具
  • 六盘水网络推广seo排名推广工具
  • 北京网站域名备案百度竞价渠道户
  • qq空间如何做微网站杭州百度人工优化
  • 房地产企业网站模板免费下载seo优化在线
  • 自己怎么做系统网站网址注册查询
  • 网站制作要花多少钱app推广项目从哪接一手
  • 高端企业网站建设蓦然郑州网站建设班级优化大师手机版下载
  • 网站代码免费下载seo策划
  • 怎样在网上建网站做电商生意友情链接怎么弄
  • 老牛影视传媒有限公司夫唯seo视频教程
  • 视频 收费 网站怎么做关键词制作软件
  • 网站开发需要哪些能力做一个私人网站需要多少钱
  • 深圳网络营销网站建设北京seo收费
  • 免费html网页模板网站app营销模式有哪些
  • 上海网站建设自学哈尔滨seo优化培训
  • 数码产品网站开发背景seo排名系统源码
  • wordpress翻译教程seo百度贴吧
  • 战地之王网站做任务重庆网络推广外包
  • 怎么建立一个网站?seo关键词有哪些类型
  • 网站和域名有关系吗文件关键词搜索工具
  • 国家建设协会官方网站天津短视频seo