2017 © Pedro Peláez
 

library regexbuilder

A fluent api that simplifies writing regular expressions

image

iak/regexbuilder

A fluent api that simplifies writing regular expressions

  • Tuesday, October 24, 2017
  • by iaK
  • Repository
  • 1 Watchers
  • 4 Stars
  • 7 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 2 Versions
  • 0 % Grown

The README.md

Regex builder

A fluent api that simplifies writing regular expressions. (for the ones of us who always forget the syntax), (*1)

Installation

Grab it using composer, (*2)

$ composer require iak/regexbuilder

```json { "require": { "iak/regexbuilder": "^1.0" } }, (*3)


Simple as that :) ## Introduction This library is for all of us that find regular expressions hard to write and impossible to remember all the different flags, look aheads, capture groups etc. Instead of spending that half hour searching stackoverflow, I hope you can easily whip up a pattern using this lib. Note. a basic understading of how regular expressions is still needed. ## Quick start First of all, use the class at the top of you file, ```php use RegexBuilder\Regex;

Now you can use it like this, (*4)

$string = "wow! this is cool!"

$match = Regex::word("wow")->symbol("!")->match($string); // wow!

Or maybe something more advanced (and demostrating some different ways of using the library), (*5)


// Match an email address $email = "info@isakberglind.se"; Regex::group("a-z0-9_-.") ->oneOrMore() ->symbol("@") ->group("a-z0-9_-].") ->oneOrMore() ->symbol(".") ->group("a-z") ->count(2,6) ->match($email); // a simple url-matcher $url = "http://www.landslide-design.se"; Regex::word(["http", "https", "ftp"]) ->symbols("://") ->capture(function ($query) { return $query->symbols("www."); }) ->optional() ->group("a-zA-Z0-9@:._") ->count(2, 255) ->symbols(".") ->group(function ($query) { return $query->range("a", "z"); }) ->count(2, 6) ->group(function ($query) { return $query ->range("a", "z") ->range("A", "Z") ->range(0, 9) ->symbols("@:_.?//"); }) ->zeroOrMore() ->match($url);

Documentation

Words, patterns and symbols

br/, (*6)

word(mixed $word = null)

Matches provided word, array of words or any word, (*7)

    $string = "This is a hard example!";

    Regex::word("simple")->replace("simple", $string);   // This is a simple example

    Regex::word(["This", "simple", "example"])->matchAll($string); // ["this", "example"]

    Regex::word()->matchAll($string) // ["this", "is", "a", "hard", "example"]

br/, (*8)

notWord()

Matches anything but a word, (*9)

    $string = "Hi!!!!! What's up?";

    Regex::notWord()->match($string); // '!!!! '

br/, (*10)

symbols(string $symbols)

Matches provided symbols (escapes string, if you don't want that, use "pattern"), (*11)

    $string = "This is &!^@? awesome!"

    Regex::symbols("&!^@?")->replace("totally", $string) // This is totally awesome

br/, (*12)

pattern(string $pattern)

Matches provided pattern br/ Aliases: raw(), (*13)

    $string = "kickass example text";

    Regex::pattern("(example|text)")->matchAll($string); // ["example", "text"]

br/, (*14)

Characters

br/, (*15)

You can match a bunch of characters using the following helper methods, (*16)

    Regex::digit();
    Regex::notDigit();
    Regex::whitespace();
    Regex::notWhitespace();
    Regex::char();
    Regex::notChar();
    Regex::hexDigit();
    Regex::octalDigit();
    Regex::newLine();
    Regex::carriageReturn();
    Regex::tab();
    Regex::verticalTab();
    Regex::formFeed();
    Regex::space();
    Regex::any();

br/, (*17)

Quantifiers

br/, (*18)

oneOrMore()

Matches one or more of preceding group, character or character set., (*19)

    $string = "Here are some numbers 123456. Cool huh?"

    Regex::digit()->oneOrMore()->match($string) // 123456

br/, (*20)

zeroOrMore()

Matches zero or more, (*21)

    $string = "AA A1A A12A";

    Regex::char()->digit()->zeroOrMore()->char()->matchAll($string) // ["AA", "A1A", "A12A"]

br/, (*22)

count(int $count/$start, int $end = null)

Matches the specified amount or the minimum and maximun count, (*23)

    $string = "1 12 123 1234";

    // Specify the exact count to match..
    Regex::digit()->count(3)->match($string); // 123

    // Or a minimum and maximum..
    Regex::digit()->count(2,4)->matchAll($string); // [12, 123, 1234]

br/, (*24)

Groups & Character sets

br/, (*25)

range(mixed $start, $mixed $end)

Specifies a range, made especially for working with character sets, (*26)

    Regex::range("a", "z"); // a-z

br/, (*27)

group(mixed $pattern/$callback)

Creates a character set, (*28)

    // Using a callback

    Regex::group(function ($builder) {
        return $builder->range("a", "z");
    });

    // Using a raw pattern

    Regex::group("a-z");

    // Produces the same;  [a-z]

br/, (*29)

Capture groups

br/, (*30)

capture(callable $callback = null)

Creates a capture group, (*31)

    $string = "Capture this if you can!";

    // you can either capture the previous statement..

    Regex::word("this")->capture();

    // .. or using a callback

    Regex::capture(function ($builder) {
        return $builder->word("this");
    });

    // Produces the same; (this)

br/, (*32)

opionalCapture(mixed $pattern/$callback)

Creates a non capturing group, (*33)

    $string = "Do not capture this if you can!";

    // you can either capture the previous statement..

    Regex::word("this")->capture();

    // .. or using a callback

    Regex::capture(function ($builder) {
        return $builder->word("this");
    });

    // Produces the same; (?:this)?

br/, (*34)

startCapture() and endCapture()

You can also surround what you want to capture with these methods, (*35)

    $string = "Capture this if you can";

    Regex::startCapture()->word("this")->endCapture(); // (this)

br/, (*36)

Look aheads & look behinds

br/, (*37)

behind(mixed $pattern/$callback)

Creates a look behind br/ Aliases: beginsWith(), before(), (*38)

    $string = "important";

    // Using a callback..
    Regex::behind(function ($builder) {
        return $builder->symbols("");
    })
    ->word()
    ->match($string);

    // .. or a raw pattern..
    Regex::behind("\*\*\*\*")->word()->match($string);

    // important

br/, (*39)

after(mixed $pattern/$callback)

Creates a look ahead, works exactly like before() br/ Aliases: endsWith(), (*40)

br/, (*41)

Other helpers

br/, (*42)

optional(mixed $characters/$start = null, $length = null)

Makes capture group, character set or character optional, (*43)

    $string = "Is it spelled color or colour?";

    // Using a characters
    Regex::word("colour")->optional("u")->matchAll($string); // ["color", "colour"]

    // Using a start and a length
    Regex::word("colour")->optional(4,1)->matchAll($string); // ["color", "colour"]

    // Make last statement optinal

    Regex::symbols("colo")->char("u")->optional()->symbols("r")->matchAll($string); // ["color", "colour"]

br/, (*44)

escape(string $pattern)

Escapes provided pattern, (*45)

    $pattern = "^[]$<";

    Regex::escape($pattern); // \^\[\]\$\<

br/, (*46)

getPattern()

Returs the built up pattern, (*47)

    Regex::group("a-zA-Z")->oneOrMore()->symbols("!!")->optional()->zeroOrMore()->getPattern(); // /[a-zA-Z]+!!?*/

br/, (*48)

release()

Removes built up pattern, (*49)

    Regex::group("a-z")->symbol("!")->release()->symbols("only this")->getPattern(); // /only this/

br/, (*50)

Matching and replacing

br/, (*51)

replace($string, $subject)

Replace built up pattern with provided string, (*52)

    $string = "This is a hashtag: @. I'm sure!";

    Regex::symbol("@")->replace("#", $string); // This is a hashtag: #. I'm sure!

br/, (*53)

match($string)

Matches the first occurrence of the built up pattern br/ Note! only return the match. If you want all capture groups, use matchWithGroups(), (*54)

    $string = "Follow me on twitter: @Isak_Berglind!";

    Regex::symbol("@")->group("a-zA-Z_")->oneOrMore()->match($string); // @Isak_Berglind

br/, (*55)

matchAll($string)

Matches all of the occurences of the built up pattern br/ Note! only return the match. If you want all capture groups, use matchAllWithGroups(), (*56)

    $string = "this is as good as it gets";

    Regex::any()->symbol("s")->matchAll($string); // ["is", "is", "as", "as", "ts"]

The Versions

24/10 2017

dev-master

9999999-dev

A fluent api that simplifies writing regular expressions

  Sources   Download

MIT

The Development Requires

by Isak Berglind

regex regular expressions

24/10 2017

v1.0

1.0.0.0

A simple regex pattern builder inspired by eloquent

  Sources   Download

MIT

The Development Requires

by Isak Berglind

regex regular expressions