- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何构建允许在上下文/状态对象上执行操作的pyparsing
程序?
我的程序示例如下所示:
load 'data.txt'
remove line 1
remove line 4
第一行应该加载一个文件,第二行和第三行是对文件内容进行操作的命令。因此,我希望在执行完所有命令后文件的内容。
load_cmd = Literal('load') + filename
remove_cmd = Literal('remove line') + line_no
more_cmd = ...
def load_action(s, loc, toks):
# load file, where should I store it?
load_cmd.setParseAction(load_action)
def remove_line_action(s, loc, toks):
# remove line, how to obtain data to operate on? where to write result?
remove_line_cmd.setParseAction(remove_cmd)
# Is this the right way to define a whole program, i.e. not only one line?
program = load_cmd + remove_cmd | more_cmd |...
# How do I obtain the result?
program.scanString("""
load 'data.txt'
remove line 1
remove line 4
""")
最佳答案
我已经写了几个这种命令解析风格的 pyparsing 例子,你可以在网上找到它们: http://pyparsing.wikispaces.com/file/view/simpleBool.py/451074414/simpleBool.py http://pyparsing.wikispaces.com/file/view/eval_arith.py/68273277/eval_arith.py
我还编写了一个简单的 Adventure 风格的游戏处理器,它接受解析的命令结构并针对游戏“世界”执行它们,该游戏“世界”充当命令执行器。我在 PyCon 2006 上展示了这个,但是来自 session 页面的链接已经过时了——你现在可以在 http://www.ptmcg.com/geo/python/confs/pyCon2006_pres2.html 找到它。 (演示文稿是使用 S5 编写的 - 将鼠标悬停在右下角以查看导航按钮)。代码位于 http://www.ptmcg.com/geo/python/confs/adventureEngine.py.txt ,代码的 UML 图位于 http://www.ptmcg.com/geo/python/confs/pyparsing_adventure.pdf。 .
我发现最有效的一般模式类似于旧的模型- View - Controller 模式。
模型是您的虚拟机,它维护命令之间的上下文。在 simple_bool
中,上下文只是推断的局部变量范围,因为每个解析的语句只是 eval
ed。在 eval_arith
中,此上下文保存在 EvalConstant._vars
字典中,其中包含预定义和解析变量的名称和值。在 Adventure 引擎中,上下文保存在 Player 对象中(包含指向当前 Room 和 Items 集合的属性),它被传递给解析后的命令对象以执行命令。
View 是解析器本身。它提取每个命令的片段并组成一个命令类的实例。命令类的 exec
方法的接口(interface)取决于您如何设置模型。但一般来说,您可以设想您定义的 exec
方法会将模型作为参数之一(如果不是唯一的话)。
然后 Controller 是一个简单的循环,它实现了以下伪代码:
while not finished
read a command, assign to commandstring
parse commandstring, use parsed results to create commandobj (null if bad parse)
if commandobj is not null:
commandobj.exec(context)
finished = context.is_finished()
如果您使用 pyparsing 实现您的解析器,那么您可以将您的 Command 类定义为该抽象类的子类:
class Command(object):
def __init__(self, s, l, t):
self.parameters = t
def exec(self, context):
self._do_exec(context)
当你定义每个命令时,对应的子类可以作为命令表达式的解析 Action 直接传递。例如,用于在迷宫中移动的简化 GO 命令如下所示:
goExpression = Literal("GO") + oneOf("NORTH SOUTH EAST WEST")("direction")
goExpression.setParseAction(GoCommand)
对于上面的抽象 Command 类,GoCommand 类可能如下所示:
class GoCommand(Command):
def _do_exec(self, context):
if context.is_valid_move(self.parameters.direction):
context.move(self.parameters.direction)
else:
context.report("Sorry, you can't go " +
self.parameters.direction +
" from here.")
通过解析像“GO NORTH”这样的语句,你得到的不是一个包含标记“GO”和“NORTH”的 ParseResults,而是一个 GoCommand 实例,它的参数包括一个命名标记“direction”,给出方向参数用于 GO 命令。
所以设计步骤是:
设计您的虚拟机及其命令界面
创建一个类来捕获虚拟机中的状态/上下文
设计您的命令及其相应的命令子类
为每个命令创建 pyparsing 解析器表达式
将 Command 子类作为解析操作附加到每个命令的 pyparsing 表达式
通过使用“|”组合所有命令表达式来创建一个整体解析器
实现命令处理器循环
关于python - Pyparsing 在上下文中操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24721385/
PEG论文描述了两种语义谓词解析表达式: 和谓词&e 不是谓词!e pyparsing 是否支持 And 谓词?或者这只是排序解析表达式的同义词?在这种情况下,它应该等同于 And 类。对吗? Not
我有以下语法和测试用例: from pyparsing import Word, nums, Forward, Suppress, OneOrMore, Group #A grammar for a
我想用这些条件解析带有嵌套括号的字符串: 元素由逗号分隔 ,或吧 | . 嵌套括号元素可能是单个字母数字或另一个嵌套括号。 每个嵌套括号元素由条 | 连接字面量导致创建一个新序列,该序列将先前的序列元
有以下我要解析的字符串: ((K00134,K00150) K00927,K11389) (K00234,K00235) 每个步骤由空格分隔,交替由逗号表示。我被困在字符串的第一部分,括号内有一个空格
所以这是取自 fourFn.py 的解析器: from pyparsing import ( Literal, Word, Group, Forward, al
所以我在制作解析器时,发现了一个问题。事实上,为了解析数字,我有: from pyparsing import Word, nums n = Word(nums) 这适用于没有千位分隔符的数字。例如,
我有一个简单的数据集,可以使用如下行进行解析: R1 (a/30) to R2 (b/30), metric 30 我需要从上面得到的唯一数据如下: R1, a, 30, R2, 192.168.0.
我正在尝试使用 pyparsing 来构建一个解析器,该解析器将匹配任意嵌套的一组括号内的所有文本。如果我们考虑这样的字符串: "[A,[B,C],[D,E,F],G] Random Middle t
from pyparsing import * class AParseActionHolder(object): def __call__(self, string, index, t):
我正在寻找一种改进使用pyparsing构建的解析器性能的方法。我阅读了关于packrat的解析,看来这确实可以帮助解析器提高性能。但是,当我启用packrat解析时,性能会变差!如果没有packra
我正在尝试使用一些特殊规则(例如相邻值和邻近值)创建 bool 查询解析器。到目前为止我创建的规则是 ## DEFINITIONS OF SYMBOLS ### NEAR = CaselessLite
我编写此脚本是为了使用类似于序言的语法来解析语句,将连接词视为具有优先级的运算符: import pyparsing as pyp alphabet = "abcdefghijklmnopqrstuv
我有一个来自游戏的文件,我正在尝试解析它。以下是摘录: id: 50 #Survival Stage bound: 1500 # phase 0 bandi
我很难理解允许在参数名称中使用“\”的语法(例如 net\)。然而,“\”也可用作续行(参见例 2)。 Ex1 工作正常,但 linebreak 和 identifier 变量之间存在冲突。 Ex1:
我正在尝试学习 pyparsing。这听起来很有希望,并且用于文本处理会很有趣。无论如何,这是我的问题: 我有一个类(class)名称列表。例如, courselist = ["Project Bas
我想利用 cStyleComment 变量,但我想专门处理它们,而不是仅仅忽略这些注释。有什么方法可以让 pyparsing 在将其识别为注释的输入片段上调用我的处理程序,然后再将其丢弃吗? 我正在处
我今天早些时候发布了一个关于同一问题的问题,但由于该问题的解决方案是切换库,而我现在对另一个库有问题,我想我会提出另一个问题......希望没关系。 所以我不想匹配以下标记: ... 我不
我有一个如下所示的数据: data = 'person(firstame="bob", lastname="stewart", dob="2010-0206", hobbies=["reading,
我正在通过解析文件 output=wilcard.parseFile(myfile) print output 我确实只得到了字符串的第一个匹配。 我有一个大的配置文件需要解析,其中的“条目”用大括号
我需要解析以下三行: Uptime is 1w2d Last reset at 23:05:56 Reason: reload 但最后两行并不总是存在,在第一次重新启动之前输出可能如下所示: Up
我是一名优秀的程序员,十分优秀!