出于某种原因,pyparsing不会为我的字符串嵌套列表:
rank = oneOf("2 3 4 5 6 7 8 9 T J Q K A")
suit = oneOf("h c d s")
card = rank + Optional(suit)
suit_filter = oneOf("z o")
hand = card + card + Optional(suit_filter)
greater = Literal("+")
through = Literal("-")
series = hand + Optional(greater | through + hand)
series_split = Literal(",")
hand_range = series + ZeroOrMore(series_split + series)
hand_range.parseString('22+,AKo-ATo,KQz')
>> ['2', '2', '+', ',', 'A', 'K', 'o', '-', 'A', 'T', 'o', ',', 'K', 'Q', 'z']
我不确定为什么pyparsing不会在22,AKo-ATo和KQz(或任何比这更深的层)创建列表.我错过了什么?
解决方法:
Pyparsing不会对这些令牌进行分组,因为您没有告诉它. Pyparsing的默认行为是将所有匹配的标记简单地串在一起.要对令牌进行分组,请将解析器中的表达式包装在一个pyparsing Group表达式中.在您的情况下,更改系列:
series = hand + Optional(greater | through + hand)
至
series = Group(hand + Optional(greater | through + hand))
另外,我建议您不要像在序列中那样实现自己的逗号分隔列表,而是使用pyparsing helper,delimitedList:
hand_range = delimitedList(series)
delimitedList采用逗号分隔符,但任何字符(甚至完整的pyparsing表达式)都可以作为delim参数给出.分隔符本身从结果中被抑制,因为delimitedList假定分隔符仅仅是重要位,列表元素之间的分隔符.
完成这两项更改后,解析结果现在开始看起来更像您要求的内容:
[['2', '2', '+'], ['A', 'K', 'o', '-', 'A', 'T', 'o'], ['K', 'Q', 'z']]
我猜你也可能想把Group围绕手定义,以构建那些结果.
如果这是一个将以某种方式进行评估的表达式(如扑克手),那么请查看pyparsing wiki上的这些示例,它们使用类作为解析操作来构造可以评估rank或boolean值的对象或者其他.
http://pyparsing.wikispaces.com/file/view/invRegex.py
http://pyparsing.wikispaces.com/file/view/simpleBool.py
http://pyparsing.wikispaces.com/file/view/eval_arith.py
如果为这些表达式构造对象,则不需要使用Group.
标签:python,pyparsing 来源: https://codeday.me/bug/20190610/1212245.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。