Skip to main content

pyparsing module - Classes and methods to define and execute parsing grammars

Project description

PyParsing – A Python Parsing Module

Build Status Coverage

Introduction

The pyparsing module is an alternative approach to creating and executing simple grammars, vs. the traditional lex/yacc approach, or the use of regular expressions. The pyparsing module provides a library of classes that client code uses to construct the grammar directly in Python code.

[Since first writing this description of pyparsing in late 2003, this technique for developing parsers has become more widespread, under the name Parsing Expression Grammars - PEGs. See more information on PEGs here .]

Here is a program to parse "Hello, World!" (or any greeting of the form "salutation, addressee!"):

from pyparsing import Word, alphas
greet = Word(alphas) + "," + Word(alphas) + "!"
hello = "Hello, World!"
print(hello, "->", greet.parseString(hello))

The program outputs the following:

Hello, World! -> ['Hello', ',', 'World', '!']

The Python representation of the grammar is quite readable, owing to the self-explanatory class names, and the use of ‘+’, ‘|’ and ‘^’ operator definitions.

The parsed results returned from parseString() is a collection of type ParseResults, which can be accessed as a nested list, a dictionary, or an object with named attributes.

The pyparsing module handles some of the problems that are typically vexing when writing text parsers:

  • extra or missing whitespace (the above program will also handle "Hello,World!", "Hello , World !", etc.)

  • quoted strings

  • embedded comments

The examples directory includes a simple SQL parser, simple CORBA IDL parser, a config file parser, a chemical formula parser, and a four- function algebraic notation parser, among many others.

Documentation

There are many examples in the online docstrings of the classes and methods in pyparsing. You can find them compiled into online docs. Additional documentation resources and project info are listed in the online GitHub wiki. An entire directory of examples can be found here.

License

MIT License. See header of the pyparsing.py file.

History

See CHANGES file.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyparsing-3.0.9.tar.gz (2.0 MB view details)

Uploaded Source

Built Distribution

pyparsing-3.0.9-py3-none-any.whl (98.3 kB view details)

Uploaded Python 3

File details

Details for the file pyparsing-3.0.9.tar.gz.

File metadata

  • Download URL: pyparsing-3.0.9.tar.gz
  • Upload date:
  • Size: 2.0 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.2.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.8.10

File hashes

Hashes for pyparsing-3.0.9.tar.gz
Algorithm Hash digest
SHA256 2b020ecf7d21b687f219b71ecad3631f644a47f01403fa1d1036b0c6416d70fb
MD5 fadc2f3bf5872bf6310576a86c3566e0
BLAKE2b-256 7122207523d16464c40a0310d2d4d8926daffa00ac1f5b1576170a32db749636

See more details on using hashes here.

File details

Details for the file pyparsing-3.0.9-py3-none-any.whl.

File metadata

  • Download URL: pyparsing-3.0.9-py3-none-any.whl
  • Upload date:
  • Size: 98.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.2.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.0 CPython/3.8.10

File hashes

Hashes for pyparsing-3.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 5026bae9a10eeaefb61dab2f09052b9f4307d44aee4eda64b309723d8d206bbc
MD5 9b7c6d2c436bc7eba41f5f239b391b4c
BLAKE2b-256 6c10a7d0fa5baea8fe7b50f448ab742f26f52b80bfca85ac2be9d35cdd9a3246

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page