pyparsing module - Classes and methods to define and execute parsing grammars
Project description
PyParsing – A Python Parsing Module
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 __init__.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
Built Distribution
File details
Details for the file pyparsing-3.1.3.tar.gz
.
File metadata
- Download URL: pyparsing-3.1.3.tar.gz
- Upload date:
- Size: 900.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.13.0b4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5d549d2a1b5e1c3e952bb55ea247bfb5ad427ea307566a350db2b3c34d4ce181 |
|
MD5 | abaafe9a8c5364c53d24ebab25432bf7 |
|
BLAKE2b-256 | 5527787992e6d7b74cd4db7a6a2ff860a84588073a2cfe183519f39624a95a95 |
File details
Details for the file pyparsing-3.1.3-py3-none-any.whl
.
File metadata
- Download URL: pyparsing-3.1.3-py3-none-any.whl
- Upload date:
- Size: 104.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.13.0b4
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1e80fdf93e6c1aeaf4702523f1d48f66d52fa6459096a8f812591157270a5896 |
|
MD5 | e8df82dba9e58722bdcde2ee6386bb2a |
|
BLAKE2b-256 | 784de616aed5bcd6556033ade80f47dae49349f74ea86d424516ea5ad94b4472 |