1

正则表达式是唯一的方法吗?慢吗?

像这样的东西?

preg_match("/^(\-){3,}/", $string);
4

4 回答 4

3

只有破折号

如果您希望字符串只有破折号,并且必须有 3 个或更多:

$match = (preg_match('/^-{3,}$/', $string) === 1);

另一种没有正则表达式的方法似乎慢了大约 25%(isset节拍strlen):

$match = (count_chars($string, 3) === '-' && isset($string[2]));

相邻的破折号

如果您想要连续 3 个或更多破折号,但可能还有其他字符(例如foo---bar):

$match = (strpos($string, '---') !== false);

一些破折号

如果您想在任何地方使用 3 个或更多破折号(例如-foo-bar-):

$match = (substr_count($string, '-') >= 3);
于 2013-08-29T00:14:21.853 回答
0

有 substr_count 功能。可能对计算字符有好处

echo substr_count('fa-r-r', '-'); // outputs 2
于 2013-08-29T00:16:32.800 回答
0

你可以这样做:

function dashtest($str) {
   $rep = str_replace('-', '', $str);
   $length = strlen($str);
   return ( $length>2 && $rep =='' ) ? true : false;
}

其他方式:

function dashtest($str) {
    for ($i=0 ; $i<strlen($str); $i++) {
        if ($str[$i]!='-') return false;
    }
    if ($i<3) return false;
    return true;
}

正则表达式方式:

if (preg_match('~^-{3,}+$~', $str)) { /*true*/} else { /*false*/}
于 2013-08-29T00:21:11.873 回答
-1

我跑了这个测试,有趣的是正则表达式是最快的

<?php


function dashtest($str) {
   $rep = str_replace( '-', '', $str );
   $length = strlen( $str );
   return ( $length < 3 || $rep != '' ) ? false : true;
}

function dashtest2($str) {
    for ($i=0 ; $i<strlen($str); $i++) {
        if ($str[$i]!='-') return false;
    }
    if ($i<3) return false;
    return true;
}



$string = '------------';



$start = microtime(true);

for ( $i=0; $i<100000; $i++ ) {
    dashtest( $string );
}

echo microtime(true) - $start;
echo "\n";



$start = microtime(true);

for ( $i=0; $i<100000; $i++ ) {
    dashtest2( $string );
}

echo microtime(true) - $start;
echo "\n";



$start = microtime(true);

for ( $i=0; $i<100000; $i++ ) {
    (preg_match('/^-{3,}$/', $string) === 1);
}

echo microtime(true) - $start;
echo "\n";

输出:

0.38635802268982

1.5208051204681 <-哈哈!

0.15313696861267

再试一次

$string = '----------------------------------------------------------------------------';

0.52067899703979

8.7124900817871

0.17864608764648

正则表达式再次获胜

于 2013-08-29T00:45:19.587 回答