Skip to main content

pyparsing - Classes and methods to define and execute parsing grammars

Project description

PyParsing – A Python Parsing Module

Version Build Status Coverage License Python versions pyparsing

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.parse_string(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 parse_string() 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.

AI Instructions

There are also instructions for AI agents to use when helping you to create your parser. They can be pulled from the GitHub project repository, at pyparsing/ai/best_practices.md. You can also tell the AI to access them programmatically after installing pyparsing, either from the CLI with python -m pyparsing.ai.show_best_practices or within python with import pyparsing; pyparsing.show_best_practices().

License

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

History

See CHANGES file.

Performance benchmarks

For usage instructions and details on the performance benchmark suite, see tests/README.md in this repository.

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.3.0b1.tar.gz (1.2 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyparsing-3.3.0b1-py3-none-any.whl (122.3 kB view details)

Uploaded Python 3

File details

Details for the file pyparsing-3.3.0b1.tar.gz.

File metadata

  • Download URL: pyparsing-3.3.0b1.tar.gz
  • Upload date:
  • Size: 1.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for pyparsing-3.3.0b1.tar.gz
Algorithm Hash digest
SHA256 c8c97e69eb6dc535eda2c43be866a6220e8d77357027202b66cae234c37709fa
MD5 e2a8451b212b0bea752f0e95ba6f4fd2
BLAKE2b-256 d05ceab45b9aed0859326d0d4223baa7389c3e353e8488ce5c712297f8849885

See more details on using hashes here.

File details

Details for the file pyparsing-3.3.0b1-py3-none-any.whl.

File metadata

  • Download URL: pyparsing-3.3.0b1-py3-none-any.whl
  • Upload date:
  • Size: 122.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for pyparsing-3.3.0b1-py3-none-any.whl
Algorithm Hash digest
SHA256 61e401b24d26cd16935179f91c908ade7eff41c9ca6ec28314b42c0f371b9772
MD5 e6d1d61cf7a7093a7ffd1dfe64a58940
BLAKE2b-256 2169be464cd78cdaa7b8974c95387ea411deba2fb441e2f9c806a94e7e6488ab

See more details on using hashes here.

Supported by

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