One undocumented requirement:
If $char_list contains null characters ("\0"), only characters before the null will be used. While PHP handles nulls in strings just fine, the data is passed to a function that is not null safe.
strpbrk
(PHP 5)
strpbrk — 文字列の中から任意の文字を探す
説明
string strpbrk ( string $haystack, string $char_list )strpbrk() は、文字列 haystack から char_list を探し、見つかった文字から始まる 文字列を返します(見つからなかった場合は FALSE を返します)。
注意: パラメータ char_list は大文字小文字を区別します。
例 2407. strpbrk() の例
<?php
$text = 'This is a Simple text.';
// これは "is is a Simple text." を出力します。なぜなら 'i' が最初にマッチするからです。
echo strpbrk($text, 'mi');
// これは "Simple text." を出力します。なぜなら大文字小文字が区別されるからです。
echo strpbrk($text, 'S');
?>
strpbrk
pzb at novell dot com
29-Jul-2007 08:09
29-Jul-2007 08:09
Evan
04-Jul-2007 12:33
04-Jul-2007 12:33
If you're not looking to duplicate the rest of the string, but instead just want the offset, in the spirit of the str*pos() functions:
<?php
function strpbrkpos($s, $accept) {
$r = FALSE;
$t = 0;
$i = 0;
$accept_l = strlen($accept);
for ( ; $i < $accept_l ; $i++ )
if ( ($t = strpos($s, $accept{$i})) !== FALSE )
if ( ($r === FALSE) || ($t < $r) )
$r = $t;
return $v;
}
?>
user at example dot net
04-Jul-2007 04:25
04-Jul-2007 04:25
For PHP versions before 5:
<?php
function strpbrk( $haystack, $char_list )
{
$strlen = strlen($char_list);
$found = false;
for( $i=0; $i<$strlen; $i++ ) {
if( ($tmp = strpos($haystack, $char_list{$i})) !== false ) {
if( !$found ) {
$pos = $tmp;
$found = true;
continue;
}
$pos = min($pos, $tmp);
}
}
if( !$found ) {
return false;
}
return substr($haystack, $pos);
}
?>
Sadly this is about ten times slower than the native implementation.
jamie dot mcardle at stpetersgv dot org
08-Jun-2007 06:54
08-Jun-2007 06:54
I wanted to use this function to look for an @ in a db entry - didn't work because I don't have this version of PHP yet, but I thought I had my issue licked. Darn it.
aidan at php dot net
21-Aug-2004 05:11
21-Aug-2004 05:11
This functionality is now implemented in the PEAR package PHP_Compat.
More information about using this function without upgrading your version of PHP can be found on the below link:
http://pear.php.net/package/PHP_Compat