File: README.md

package info (click to toggle)
pyparsing 3.3.2-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 12,200 kB
  • sloc: python: 30,867; ansic: 422; sh: 112; makefile: 24
file content (59 lines) | stat: -rw-r--r-- 2,331 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# Regex Inverter

This directory contains a web-based Regex Inverter tool powered by [PyScript](https://pyscript.net/) and `pyparsing`.

## Overview

The Regex Inverter allows you to enter a regular expression and generate all possible strings that match it. It is particularly useful for visualizing the expansion of character classes, repetitions, and alternatives.

### Key Features:
- **Expansion of Regex Patterns:** Generates matching strings for patterns like `[A-Z]{3}\d{3}`.
- **Client-Side Processing:** All computations happen in your browser using PyScript, so no data is sent to a server.
- **Progress Tracking:** Shows the total count of possible matches, even if they exceed the display limit.

### Supported Syntax:
- Character sets: `[a-z]`, `[0-9A-F]`, `[^0-9]`
- Repetitions: `{n}`, `{min,max}`, `{,max}`
- Alternatives: `apple|orange`
- Groups: `(abc|def)`
- Macros: `\d`, `\w`, `\s`, `\D`, `\W`, `\S`
- Dot: `.` (matches printable characters)

### Constraints:
- **Unbounded operators `+` and `*` are not supported.** You must use explicit range repetitions like `{1,10}` instead of `+` to prevent infinite or excessively large result sets that would crash the browser.

## Files

- `index.html`: The web interface and PyScript configuration.
- `inv_regex.py`: The core inversion logic using `pyparsing`.

## Run the Regex Inverter web page online

To run the Regex Inverter from the Github Pages server, open your browser 
and go to [https://ptmcg.github.io/regex_inverter/](https://ptmcg.github.io/regex_inverter/).

## How to Run Locally

To run the Regex Inverter on your own machine:

1.  Open a terminal or command prompt.
2.  Navigate to this directory:
    ```bash
    cd examples/regex_inverter
    ```
3.  Start a local Python web server:
    ```bash
    python -m http.server
    ```
4.  Open your web browser and go to:
    [http://localhost:8000](http://localhost:8000)

## Deployment

To deploy this to a web server:

1.  Upload both `index.html` and `inv_regex.py` to the same directory on your web server.
2.  Ensure your server is configured to serve `.html` files (most are by default).
3.  Access the `index.html` file through its URL.

Since this is a static site (using PyScript to run Python in the browser), you can even host it on GitHub Pages or any other static site hosting service.