ilario-pierbattista / reverse-regex
Convert Regular Expressions into text, for testing. Fork of icomefromthenet/reverse-regex
Installs: 13 429
Dependents: 1
Suggesters: 1
Security: 0
Stars: 2
Watchers: 0
Forks: 38
Open Issues: 2
pkg:composer/ilario-pierbattista/reverse-regex
Requires
- php: ^7.4 | ^8
- doctrine/collections: ^1.6.5
- doctrine/lexer: ^1.2.1 || ^2
- symfony/polyfill-mbstring: ^1.20.0
Requires (Dev)
- phpunit/phpunit: ^9
Conflicts
- dev-master
- 0.5.0
- 0.4.0
- 0.3.1
- 0.3.0
- v0.2.0.0
- v0.1.0.0
- v0.0.6.3
- v0.0.6.2
- v0.0.6.1
- v0.0.6
- v0.0.5
- v0.0.4
- v0.0.3
- v0.0.2
- v0.0.1
- dev-2510_unbound_generator
- dev-2510_fix_some_phpstan_errors
- dev-2510_configure_phpstan_now
- dev-2510_php81
- dev-2510_configure_cs_fixer
- dev-2510_update_docker_compose
- dev-2212_php8
- dev-2210_update_composer_dependencies
This package is auto-updated.
Last update: 2025-10-11 20:07:31 UTC
README
This is a fork of https://github.com/icomefromthenet/ReverseRegex (that provides
icomefromthenet/reverse-regex).
Use Regular Expressions to generate text strings can be used in the following situations:
- Writing test data for web forms.
- Writing test data for databases.
- Generating test data for regular expressions.
##Example
use ReverseRegex\Lexer; use ReverseRegex\Random\SimpleRandom; use ReverseRegex\Parser; use ReverseRegex\Generator\Scope; # load composer require "vendor/autoload.php"; $lexer = new Lexer('[a-z]{10}'); $gen = new SimpleRandom(10007); $result = ''; $parser = new Parser($lexer,new Scope(),new Scope()); $parser->parse()->getResult()->generate($result,$gen); echo $result;
Produces
jmceohykoa
aclohnotga
jqegzuklcv
ixdbpbgpkl
kcyrxqqfyw
jcxsjrtrqb
kvaczmawlz
itwrowxfxh
auinmymonl
dujyzuhoag
vaygybwkfm
Other examples
##Installing
To install use composer
composer require ilario-pierbattista/reverse-regex
Writing a Regex
- Escape all meta-characters i.e. if you need to escape the character in a regex you will need to escape here.
- Not all meta-characters are suppported see list below.
- Use
\X{####}to specify unicode value use[\X{####}-\X{####}]to specify range. - Unicdoe
\pnot supported, I could not find a port of UCD to php, maybe in the future support be added. - Quantifiers are applied to left most group, literal or character class.
- Beware of the
+and*quantifers they apply a possible maxium number of occurances up toPHP_INT_MAX.
Regex Support
| Example | Description | Resulting String |
|---|---|---|
| (abcf) | Support literals this would generate string | `abcf` |
| \((abcf)\) | Escape meta characters as you normally would in a regex | `(abcf)` |
| [a-z] | Character Classes are supported | `a` |
| a{5} | Quantifiers supported always last group or literal or character class | `aaaaa` |
| a{1,5} | Range Quantifiers supported | `aa` |
| a|b|c | Alternation supported pick one of three at random | `b` |
| a|(y|d){5} | Groups supported with alternation and quantifiers | `ddddd` or `a` or `yyyyy` |
| \d | Digit shorthand equ [0-9] | `1` |
| \w | word character shorthand equ [a-zA-Z0-9_] | `j` |
| \W | Non word character shorthand equ [^a-zA-Z0-9_] | `j` |
| \s | White space shorthand ASCII only | ` ` |
| \S | Non White space shorthand ASCII only | `i` |
| . | Dot all ASCII characters | `$` |
| * + ? | Short hand quantifiers, recommend not use them | |
| \X{00FF}[\X{00FF}-\X{00FF}] | Unicode ranges | |
| \xFF[\xFF-\xFF] | Hex ranges |