Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vjeux/phpmatch
Wrapper around preg_match to make it user friendly
https://github.com/vjeux/phpmatch
Last synced: about 1 month ago
JSON representation
Wrapper around preg_match to make it user friendly
- Host: GitHub
- URL: https://github.com/vjeux/phpmatch
- Owner: vjeux
- Created: 2010-11-26T08:30:27.000Z (about 14 years ago)
- Default Branch: master
- Last Pushed: 2011-12-13T19:20:35.000Z (about 13 years ago)
- Last Synced: 2024-04-14T15:07:23.808Z (9 months ago)
- Language: PHP
- Homepage: http://blog.vjeux.com/
- Size: 102 KB
- Stars: 2
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
[phpMatch](http://blog.vjeux.com/) - user friendly preg_match
================================preg_match is your ally when you are working on web spiders, however it is not really convenient to work with. Those small helpers will help you capture elements with more ease!
* The result is directly in the return value and have the form you expect
* Capturing one element will give you that element, it won't be wrapper on an array
* No more duplicate in the array when naming the elements
* The matched string is removed from the result. It is annoying when dumping the result and who ever used it!?
* Regex is configured properly to fit your needs
* ` is used as regex escape character
* ms options to be multi-line ready
* tabs and new lines are removed to let you write readable regexMatch
-----### Prototype
match($str, $regex, $trim = true)
Takes
* **str**: the string to execute the search on
* **regex**: the regular expression to match
* ` is automatically used as regex escaping character
* \n and \t are trimmed (not spaces!)
* Multiple line environment
* **trim**: Optional: false to disable the removal of the \n and \tReturns
* **false**: is nothing is matched
* **string**: if there's one non-named captured element
* **associative array**: if there are named captured elements
* **array**: all the captured elements### Examples
For all the examples, this is the $file variable.$file = <<Name
EOF;The value is directly returned by the function, no need to do write another line to get the result. false is returned when nothing is matched.
$none = match($file, 'href="([^"]+)"');
// falseIf you are only capturing one element, it is given as is. No more useless single array.
$string = match($file, 'id="([0-9]+)"');
// 123When naming elements, all the numbered values are removed!
$assoc = match($file, '');
// array("class" => "abc", "id" => "123")The first element of the resulting array (the matched string) is removed, you now only get what you wanted!
$array = match('', '');
// array("abc", "123")When working on real files, your regexes can be complex. You can use tabs and line breaks to make it more readable.
The . is also capturing \n, this will let you use the [.*? trick](http://www.google.fr/search?q=regex+non+greedy) to magically capture the content you want :)// WARNING: Make sure you convert the indentation to TABs when copy & pasting the code!
');
$multiline = match($file, '
// array("class" => "abc", "id => "123", "name" => "\n\t\t\n\t\t\tName\n\t\t")
Match All
---------match_all is the same as match but captures more than the first.
### Prototype
match_all($str, $regex, $trim = true)
Takes
* **str**: the string to execute the search on
* **regex**: the regular expression to match
* ` is automatically used as regex escaping character
* \n and \t are trimmed (not spaces!)
* Multiple line environment
* **trim**: Optional: false to disable the removal of the \n and \tReturns
* Array of
* **string**: if there's one non-named captured element
* **associative array**: if there are named captured elements
* **array**: all the captured elements### Examples
$file = <<Vjeux
Curse
EOF;$singles = match_all($file, '(.*?)');
print_r($singles);
// array("Vjeux", "Curse", "Google")$arrays = match_all($file, '(.*?)');
print_r($arrays);
// array(
// array("http://blog.vjeux.com/", "Vjeux"),
// array("http://www.curse.com/", "Curse"),
// array("http://www.google.com/", "Google"))$associatives = match_all($file, '(?P.*?)');
// array(
// array("link" => "http://blog.vjeux.com/", "name" => "Vjeux"),
// array("link" => "http://www.curse.com/", "name" => "Curse"),
// array("link" => "http://www.google.com/", "name" => "Google"))