- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在用 python 实现 prolog 的方言。我正在使用美妙的 pyparsing
用于此目的的模块,我发现它非常适用于涉及上下文无关语法的其他项目。
随着我转向上下文相关语法,我逐渐习惯了pyparsing
的风格。 pyparsing.nestedExpr
和 pyparsing.delimitedList
是我仍然熟悉的两件事。现在我遇到了 pyparsing.delimitedList
的问题;它实现了我正在寻找的东西,但下面示例代码中的每个单独的 term
都在列表中返回,我没有在任何条件下使用 pyparsing.Group
。
重构以使用 pyparsing.nestedExpr
和 pyparsing.infixNotation
是解决此问题后我的下一个待办事项,所以请不要因为我没有使用它们而 panic 然而。我还怀疑,但还不知道,我必须阻止匹配规则表达式左侧的 term_list
。这就是说,该代码仍在进行中,随着我对库的进一步试验,它会随着时间的推移发生重大变化。
我觉得pyparsing.ungroup
可以解决问题,但是pyparsing.ungroup(pyparsing.delimitedList...
似乎没有任何作用这种情况。
result = root.parseString('''
A :- True
Z :- 5
''')
print(result.dump())
print(result.rules[0].goals)
[['A', 'True'], ['Z', '5']]
- rules: [['A', 'True'], ['Z', '5']]
[0]:
['A', 'True']
- goals: [['True']]
[0]:
['True']
[1]:
['Z', '5']
- goals: [['5']]
[0]:
['5']
[['True']]
[['A', 'True'], ['Z', '5']]
- rules: [['A', 'True'], ['Z', '5']]
[0]:
['A', 'True']
- goals: ['True']
[1]:
['Z', '5']
- goals: ['5']
['True']
import pyparsing as pp
# These types are the language primitives
atom = pp.Word(pp.alphanums)
number = pp.Word(pp.nums)
variable = pp.Word(pp.alphanums)
string = pp.quotedString
# Terms are the basic unit of expression here
compound_term = pp.Forward()
term = (atom ^ number ^ variable ^ pp.Group(compound_term))('terms*')
# A compound term includes a few rules for term composition, such as lists or an atom containing arguments
term_list = pp.Forward()
compound_term <<= \
string ^ \
term_list ^ \
atom('functor') + pp.Suppress('(') + pp.delimitedList(term('arguments*')) + pp.Suppress(')')
term_list <<= pp.Suppress('[') + pp.delimitedList(term('items*')) + pp.Suppress(']')
# The rule operator is an infix operator represented by :-
# On the right side, multiple goals can be composed using AND or OR operators
rule = pp.Group(
term + pp.Suppress(':-') + \
pp.delimitedList(term('goals*')) \
)('rules*')
root = pp.ZeroOrMore(rule)
result = root.parseString(
'''
A :- True
Z :- 5
''')
print(result.dump())
print(result.rules[0].goals)
最佳答案
最初的问题是 compound_term
中存在 Group
:
term = (atom ^ number ^ variable ^ pp.Group(compound_term))('terms*')
应该是
term = (atom ^ number ^ variable ^ (compound_term))('terms*')
进行更改并在您的规则中添加“lhs”结果名称后(见下文),我明白了:
[['A', 'True'], ['Z', '5']]
- rules: [['A', 'True'], ['Z', '5']]
[0]:
['A', 'True']
- goals: ['True']
- lhs: 'A'
[1]:
['Z', '5']
- goals: ['5']
- lhs: 'Z'
['True']
一些补充说明:
atom
定义为
atom = pp.Word(pp.alphanums)
这也将作为 atom
匹配“123”。为确保您只获得变量 names ,请使用 pp.Word(pp.alphas, pp.alphanums)
。这表示首字母必须是字母,任何后续字母都可以是字母或数字(与 variable
相同)。
我不会在术语上添加结果名称“terms*”,因为它最终会在“:-”运算符的左右两侧使用。我建议人们通常 保留结果名称的附件,直到在更高级别的表达式中使用该表达式。例如,我会将规则定义为:
rule = pp.Group(term("rule_lhs")
+ ":-"
+ pp.delimitedList(term)("goals")
)
我不会真正称“:-”为“中缀”运算符,我将“+”、“-”、“AND”、“OR”等运算符视为中缀运算符。例如,我认为 x :- y :- z
是无效的。您可能会执行类似这样的操作来添加“AND”和“OR”运算符:
logical_term_expression = pp.infixNotation(term,
[
("&&", 2, pp.opAssoc.LEFT,),
("||", 2, pp.opAssoc.LEFT,),
])
在 term
中有一个结果名称真的会把事情搞得一团糟,更有可能在你的运算符元组上使用类,正如你在像 simple_bool.py 这样的 pyparsing 例子中看到的。
您提到使用 nestedExpr
- 请不要这样做。该助手最适用于为 C 代码之类的东西编写扫描器,在这种情况下您可能只想跳过一些嵌套的大括号而不实际解析内容。在您的 DSL 中,您会希望正确解析所有内容 - 但我认为 infixNotation
可能就是您所需要的。
关于python - 如何打开 pyparsing 辅助函数的结果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65534745/
我正在尝试 specFlow 辅助,但不确定如何从表中创建类属性。 想象一下我有这门课: public class Tracking { public string Category { ge
我如何使用带 IOS 应用程序的辅助 GPS 来计算给定区域(例如建筑物)内部(或外部)某人的位置? 是否有可能在几英尺内就足够准确? 这样做正确吗? 是否可以在计算中使用多个 wifi 连接? 最佳
我在 wiki 和其他一些文本中看到,他们说冒泡排序、插入排序、选择排序等的空间复杂度是 O(1) 辅助。它们是否指的是程序中使用的变量所需的常量存储单元。 最佳答案 是的,他们指的是大多数排序都是就
默认情况下,页面上有 3 个点击事件(蓝色 X、蓝色 +、灰色 X)。每个人都会打开一个模式框。 每个模式框都有一个按钮。其中两个模态框,一个用于蓝色 X,一个用于蓝色 +,内部都有功能按钮。当我单击
我正在寻找 Kotlin 的 gigasecond 练习的解决方案:http://exercism.io/exercises/kotlin/gigasecond/readme 。我可以理解它如何需要两
我基本上刚刚开始使用 PyGame 进行开发,但我在整个 Sprite 概念方面遇到了麻烦。我一直在到处寻找有关如何使用它的指南,但似乎找不到任何指南。我想知道这一切是如何运作的基本概念。这是我一直在
我有一些无法运行的 JavaScript 代码。我尝试过移动一些东西,并更改一些关键字,但到目前为止没有任何效果。我会让你们尝试一下。 这是 JavaScript 文件: var GAME =
我有这个注册网页是我在帮助下创建的,感谢这里的人。在尝试使其响应之前,我只是做了一些调整。如何在复选框及其文本和底部的 div 之间创建空间而没有间隙。有什么建议吗? https://jsfiddle
我正在尝试检查是否启用了 WiFi 辅助。当我连接到我的接入点以获取一些数据时,我遇到了问题,当我的连接不佳时,我的蜂窝数据被使用并且它干扰了我的接入点。有什么方法可以检查是否启用了此选项? 最佳答案
为了安全起见,我希望使用异地复制/辅助 Blob 存储容器作为 AzureML 数据存储的数据源。所以我执行以下操作: 新数据存储 输入名称 + Azure Blob 存储 + 手动输入 对于 URL
我的讲师现在有一个我以前从未见过的奇怪习惯,我想知道这是 Haskell 标准还是他的编程风格的怪癖。 基本上,他经常会做这样的事情: functionEx :: String -> Int func
我想从可移动SD卡中删除文件,我尝试了很多方法但没有效果。 尝试过: file.delete(); 和 File file = new File(selectedFilePath); boolean
我正在开发一款 Android 应用,用户必须能够在其中进行身份验证,然后调用 YouTube 数据 API。 我可以毫无问题地使用主帐户对用户进行身份验证,使用 Google 登录对我和用户来说一切
命令: sudo mv /temp/hello.txt /path/to/destination/ 然后我通过 key 存储添加了密码。 我确信写在 sudo.password 中的密码是正确的。
我需要编写一个 java 代码来获取给定集群的辅助名称节点的 IP 地址。给定集群的 Namenode 的 IP 地址。 我能够获取数据节点和名称节点的报告,但无法找到获取辅助名称节点的 IP 地址的
Cay Horstmann 的书《不耐烦的 Scala》中的一个非常简单的练习一直让我感到困惑。是关于primary , auxiliary和 default primary构造函数: ex 5.10
我正在尝试确定 Google Cloud DNS 是否支持通过 NOTIFY 请求进行辅助 DNS (AXFR/IXFR) 传输?我在网上找不到任何东西,Google 也没有明确声明不支持它。 最佳答
我有一个简单的 Kotlin 类: data class ValveSpan(val begin:Duration, val end:Duration, val key:String):Compara
我有一个与最初在 UISplitView 中加载辅助 View 相关的快速问题。目前,我已经在 masterVC.swift 中获得了代码,可以用数组中的第一个对象(如果有)填充detailsVC。这
我正在使用这个命令来获取另一个命令的进程 ID: ps aux | grep 7000.conf | awk '{print $2}' 这将返回两个 PID: 7731 22125 我只想要第一个。第
我是一名优秀的程序员,十分优秀!