假设你有这个字符串:
hiThere
找到第一个大写字符的最快方法是什么? (本例中为T
)
我担心表现,因为有些词很长。
答案 0 :(得分:18)
最简单的方法是使用preg_match(如果只有1个匹配)或preg_match_all(如果你想要所有的匹配) http://php.net/manual/en/function.preg-match.php
preg_match_all('/[A-Z]/', $str, $matches, PREG_OFFSET_CAPTURE);
不确定它是否是最快的..
答案 1 :(得分:6)
为了找到第一个大写字符,我会使用preg_match
的PREG_OFFSET_CAPTURE
标志:
$string = "hiThere";
preg_match( '/[A-Z]/', $string, $matches, PREG_OFFSET_CAPTURE );
print_r( $matches[0] );
返回以下内容:
Array ( [0] => T [1] => 2 )
你可以把这个逻辑包装成一个函数并一遍又一遍地使用它:
function firstUC ( $subject ) {
$n = preg_match( '/[A-Z]/', $subject, $matches, PREG_OFFSET_CAPTURE );
return $n ? $matches[0] : false;
}
echo ( $res = firstUC( "upperCase" ) ) ? $res[1] : "Not found" ;
// Returns: 5
echo ( $res = firstUC( "nouppers!" ) ) ? $res[1] : "Not found" ;
// Returns: Not found
答案 2 :(得分:5)
其他做法
$stringCamelCase = 'stringCamelCase';// hiThere
使用preg_split():
$array = preg_split('#([A-Z][^A-Z]*)#', $stringCamelCase, null, PREG_SPLIT_DELIM_CAPTURE | PREG_SPLIT_NO_EMPTY);
echo strlen($array[0]);// $array = ['string', 'Camel', 'Case']
使用strpbrk():
$CamelCase = strpbrk($stringCamelCase, 'ABCDEFGHIJKLMNOPQRSTUVWXYZ');
echo strpos($stringCamelCase, $CamelCase);
答案 3 :(得分:2)
我想这样做:
strlen(preg_replace("/^([a-z]*)[A-Z].*$/", "$1", $str));
isThis
=> 2
largerWord
=> 6
答案 4 :(得分:1)
使用strpos()
。
echo strpos($string, "T");
答案 5 :(得分:1)
有了这个功能最难的时间,直到我发现阵列是多维的。没有看到任何人的代码提到这一点。要获得我使用的第一封大写字母的位置:
<?php
$field = "i_select_Interior_Quote";
preg_match( '/[A-Z]/', $field, $m, PREG_OFFSET_CAPTURE );
$posi=$m[0][1];
echo '<br><br>'.$posi; // outputs 9
?>
答案 6 :(得分:0)
a-z字符的解决方案。可能不会工作unicode
preg_match('/[A-Z]/', $str, $m);
if(isset($m[1])) {
echo 'First upper char is '.$m[1].' and located at '. strpos($string, "T");
}
else {
'There is no upperchar';
}
答案 7 :(得分:0)
这是一个(或多或少)一行解决方案。
$pos = strcspn($string, 'ABCDEFGHJIJKLMNOPQRSTUVWXYZ');
strcspn将返回第二个参数中任何字符第一次出现的位置,如果没有字符则返回字符串的长度。
返回str1初始段的长度,该段不包含str2中的任何字符。
$pos = strcspn($string, 'ABCDEFGHJIJKLMNOPQRSTUVWXYZ');
if ($pos < strlen($string)) {
echo "capital letter as index $pos";
}
答案 8 :(得分:0)
我在自己的应用程序中使用的内容:
function acronyms($s){
$s=str_replace(array('& ','of ','the ','and '),'',strtolower($s));
$s=ucwords(trim($s)); //Collecting data
if(strlen($s)>0 && preg_match_all('/[A-Z]/',$s,$m)) return implode('',$m[0]);
return $s;
}