Как использовать Pyparsing Group с SkipTo для разбора файла? - PullRequest
1 голос
/ 22 апреля 2019

Когда я использовал pyparsing SkipTo вместе с другим парсером, анализ файла кажется зависшим.

unexpected = pp.SkipTo(pp.LineEnd())('unexpected*')
rules = pp.Group(predefined_parser) | unexpected

parser = pp.Dict(pp.OneOrMore(rules)
parser.ignore('*' + pp.restOfLine)
parser.parseFile(filename, True)

Я включил setDebug, вот отладочное сообщение. Любые идеи высоко ценятся.

Match Dict:([{Group:({Combine:({"something" W:(_) Combine:({W:(ABCD...) [W:(0123...)]}) W:(_) {"sth1" | "sth2"}}) Suppress:("=") W:(0123...)}) | SkipTo:(LineEnd)}]...) at loc 0(1,1)

После того, как я переключился на следующее, выдается AttributeError.

unexpected = pp.SkipTo(pp.LineEnd(), include=True)('unexpected*')

Вот сообщение AttributeError.

File "/nfs/pdx/disks/icf_gwa_002/ylim13/anaconda2/lib/python2.7/site-packages/pyparsing.py", line 1599, in parseFile
  return self.parseString(file_contents, parseAll)
File "/nfs/pdx/disks/icf_gwa_002/ylim13/anaconda2/lib/python2.7/site-packages/pyparsing.py", line 1078, in _parseNoCache
  tokens = self.postParse( instring, loc, tokens )
File "/nfs/pdx/disks/icf_gwa_002/ylim13/anaconda2/lib/python2.7/site-packages/pyparsing.py", line 3249, in postParse
  dictvalue = tok.copy() #ParseResults(i)
AttributeError: 'str' object has no attribute 'copy'

1 Ответ

1 голос
/ 23 апреля 2019

Краткий ответ - измените:

    | pp.SkipTo(pp.LineEnd(), include=True)

на:

    | pp.SkipTo(pp.LineEnd(), include=True).suppress()

Когда он передается в Dict, он видит два значения, созданные SkipTo, поэтому предполагает, что это проанализированныйрезультаты из пары ключ-значение, которые будут добавлены в совокупный диктант.Подавляя этот результат, Dict получает пустую строку, которую он игнорирует.

...