python - 解析示例

标签 python pyparsing

这是我第一次尝试使用pyparsing,我想问一下 如何过滤此示例行:

survey = '''GPS,PN1,LA52.125133215643,LN21.031048525561,EL116.898812'''

得到如下输出:1,52.125133215643,21.031048525561,116.898812

一般来说,我在理解 pyparsing 逻辑方面有问题,所以对此有任何帮助 示例将不胜感激。谢谢

最佳答案

你可以从这样的事情开始:

from pyparsing import *

survey = '''GPS,PN1,LA52.125133215643,LN21.031048525561,EL116.898812'''

number = Word(nums+'.').setParseAction(lambda t: float(t[0]))
separator = Suppress(',')
latitude = Suppress('LA') + number
longitude = Suppress('LN') + number
elevation = Suppress('EL') + number

line = (Suppress('GPS,PN1,')
        + latitude
        + separator
        + longitude
        + separator
        + elevation)

print line.parseString(survey)

脚本的输出是:

[52.125133215643, 21.031048525561, 116.898812]

编辑:您可能还想考虑 lepl ,这是一个类似的库,有很好的文档记录。与上述脚本等效的脚本是:

from lepl import *

survey = '''GPS,PN1,LA52.125133215643,LN21.031048525561,EL116.898812'''

number = Real() >> float

with Separator(~Literal(',')):
    latitude = ~Literal('LA') + number
    longitude = ~Literal('LN') + number
    elevation = ~Literal('EL') + number

    line = (~Literal('GPS')
             & ~Literal('PN1')
             & latitude
             & longitude
             & elevation)

print line.parse(survey)

关于python - 解析示例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8507694/

相关文章:

python - minAreaRect OpenCV [Python] 返回的裁剪矩形

python - 如何将 PDF 从 base64 字符串转换为文件?

没有 socket.makefile() 的 python socket readline

python - 如何获取 Pandas 中的每第 n 列?

python - pyparsing 不是嵌套列表......为什么?

python - 在Python中解析自定义配置格式

python - 等到具体时间

python - pyparsing:组合多个元素的setResultsName

python - 在 DSL 的算术语法中评估函数

python - 是否可以使用 pyparsing 解析非平凡的 C 枚举?