Solved

preg_match in PHP

Posted on 2014-11-20
6
132 Views
Last Modified: 2014-11-23
Any idea what this preg_match want to do ? Tks

if(!preg_match(“/^[4]{1,1}[0-9]{12,15}$/”,$value))
0
Comment
Question by:AXISHK
6 Comments
 
LVL 11

Accepted Solution

by:
Radek Baranowski earned 200 total points
ID: 40456786
http://www.autohotkey.com/docs/misc/RegEx-QuickRef.htm

it matches a string that
begins (^) with exactly one ({1,1}) "4" then is followed by 12 to 15 digits 0-9

so, the pattern like:

41234567890123

hope this helps!
0
 
LVL 34

Assisted Solution

by:Dan Craciun
Dan Craciun earned 100 total points
ID: 40456816
I think the string was done so you can quickly change the amounts of digits at the beginning, or else {1,1} is meaningless.
As is, the pattern can be written as
^4\d{12,15}$

HTH,
Dan
0
 

Author Comment

by:AXISHK
ID: 40456898
^4\d{12,15}$

Does it mean starting with '4", following by 12 - 15 digit number ? Tks
0
Announcing the Most Valuable Experts of 2016

MVEs are more concerned with the satisfaction of those they help than with the considerable points they can earn. They are the types of people you feel privileged to call colleagues. Join us in honoring this amazing group of Experts.

 
LVL 11

Expert Comment

by:Radek Baranowski
ID: 40456901
yes.
0
 
LVL 109

Assisted Solution

by:Ray Paseur
Ray Paseur earned 200 total points
ID: 40457118
There is one other problem.  The apparent double quote wrapping the regular expression are not, in fact, quotes.  They may be something that wormed its way in from cut/paste with Microsoft word?  You may want to read this article about how PHP handles quote marks.  It's an important part of the language with many effects on the meaning of the code.
http://www.experts-exchange.com/Web_Development/Web_Languages-Standards/PHP/A_12241-Quotation-Marks-in-PHP.html

You may find that your regular expressions are easier to craft and understand if you write them like this, with comments to explain the intent of each segment of the expression:
$rgx 
= '#'           // REGEX DELIMITER (REQUIRED AT FRONT AND BACK OF EXPRESSION)
. '^'           // AT THE START OF THE STRING
. '[4]'         // CHARACTER CLASS THAT INCLUDES ONLY "4"
. '{1,1}'       // EXACTLY ONE OF THIS CHARACTER CLASS
. '[0-9]'       // CHARACTER CLASS THAT INCLUDES DIGITS 0-9
. '{12,15}'     // BETWEEN 12 AND 15 OF THE DIGITS
. '$'           // AT THE END OF THE STRING
. '#'           // REGEX DELIMITER
;

Open in new window

In the instant case this looks like  the regex is intended to match certain kinds of credit card numbers.
0
 

Author Closing Comment

by:AXISHK
ID: 40461371
Tks
0

Featured Post

Networking for the Cloud Era

Join Microsoft and Riverbed for a discussion and demonstration of enhancements to SteelConnect:
-One-click orchestration and cloud connectivity in Azure environments
-Tight integration of SD-WAN and WAN optimization capabilities
-Scalability and resiliency equal to a data center

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
PHP not parsing ' character 12 46
how to use a switch statement with heredoc 11 33
Currency in SQL? 2 32
AJAX, If No returns don't let the AJAX Call run again 2 21
Deprecated and Headed for the Dustbin By now, you have probably heard that some PHP features, while convenient, can also cause PHP security problems.  This article discusses one of those, called register_globals.  It is a thing you do not want.  …
These days socially coordinated efforts have turned into a critical requirement for enterprises.
The viewer will learn how to dynamically set the form action using jQuery.
The viewer will learn how to create and use a small PHP class to apply a watermark to an image. This video shows the viewer the setup for the PHP watermark as well as important coding language. Continue to Part 2 to learn the core code used in creat…

828 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question