我不是很擅长找到正则表达式的正确自动化,以生成不同的表达式,但是当这涉及到PHP中的脚本时,它就变成了我的屁股。我无法证明自己能够在preg_match中编写一个“适合”表达式的模式,如:123-23-345 ... 123-34-456 .... 12-234-56 .....它应该是3组数字,其中每个组,从左到右分类,并且每个下一组都没有比前一组的最大数字大的数字。这个:123-23-456会错,因为23中的2比123中的3小.123-43-45再次出错,因为43应该是34 ...
这应该可以帮助我验证可能只包含该类型内容的字段。它应该是正则表达式验证,而不是解析,拆分......的函数。
答案 0 :(得分:2)
嗯,我认为不会有正则表达式的解决方案。 所以我在这里编写了你需要的功能:
function isValidDigitExpression($string) {
$flag = preg_match('/^(\d+)\-(\d+)\-(\d+)$/', $string, $matches);
if (!$flag) return false;
// Check correct sorting by splitting digit string to array
for ($i = 1; $i <= 3; $i++ ) {
$block[$i] = str_split($matches[$i]);
$compare = $block[$i];
sort($compare);
if ($compare != $block[$i]) return false;
}
// Compare Min and Max digits of neighboring digit blocks
return (max($block[1]) <= min($block[2]) and max($block[2]) <= min($block[3]));
}
$string = "123-34-356"; // Failure, because 3 < 4 comparing Block 2 and Block 3
echo isValidDigitExpression($string) ? "SUCCESS" : "FAILURE";
答案 1 :(得分:1)
除了仅使用preg_
函数外,您还需要使用其他一些条件匹配。
<?php
$str = "123-34-456";
preg_match( "/^.*?(\d)\-(\d).*?(\d)\-(\d)/", $str, $matches );
$flag = true;
if( $matches[2] < $matches[1] )
$flag = false;
if( $matches[4] < $matches[3] )
$flag = false;
echo ( !$flag ) ? "ERROR" : "NO ERROR";
?>
类似地,您可以匹配相应部分中的数字,迭代所有文字,并再次使用该标记来表示不匹配的值。
这样的事情:
<?php
$str = "132-34-456";
preg_match( "/^(\S+)\-(\S+)\-(\S+)$/", $str, $matches );
$flag = true;
for( $i = 0; $i < strlen($matches[1]) - 1; $i++ ) {
if( $matches[1][$i+1] < $matches[1][$i] ) {
$flag = false;
break;
}
}
for( $i = 0; $i < strlen($matches[2]) - 1; $i++ ) {
if( $matches[2][$i+1] < $matches[2][$i] ) {
$flag = false;
break;
}
}
for( $i = 0; $i < strlen($matches[3]) - 1; $i++ ) {
if( $matches[3][$i+1] < $matches[3][$i] ) {
$flag = false;
break;
}
}
echo ( !$flag ) ? "ERROR" : "NO ERROR";
?>
显然,这不是最佳/最优化的解决方案。