It took me some time to understand the way this function works…
I’ve compiled my own explanation with my own words that is more understandable for me personally than the official one or those that can be found in different tutorials on the web.
Perhaps, it will save someone several minutes…
<?php
strspn(string $haystack, string $char_list [, int $start [, int $length]])
?>
The way it works:
- searches for a segment of $haystack that consists entirely from supplied through the second argument chars
- $haystack must start from one of the chars supplied through $char_list, otherwise the function will find nothing
- as soon as the function encounters a char that was not mentioned in $chars it understands that the segment is over and stops (it doesn’t search for the second, third and so on segments)
- finally, it measures the segment’s length and return it (i.e. length)
In other words it finds a span (only the first one) in the string that consists entirely form chars supplied in $chars_list and returns its length
strspn
(PHP 4, PHP 5)
strspn — マスクに一致する最初のセグメントの長さを返す
説明
int strspn
( string $str1
, string $str2
[, int $start
[, int $length
]] )
マスクに一致する最初のセグメントの長さを求めます。
たとえば、
<?php
$var = strspn("42 is the answer, what is the question ...", "1234567890");
?>
パラメータ
- str1
-
最初の文字列。
- str2
-
次の文字列。
- start
-
調べ始める位置。 負の値を指定すると、文字列の末尾から数えた位置となります。
- length
-
調べる文字列の長さ。 負の値を指定すると、文字列の末尾からの長さとなります。
返り値
str1 の中で、全て str2 の中の文字からなる最初のセグメントの長さを返します。
変更履歴
| バージョン | 説明 |
|---|---|
| 4.3.0 | start および length が追加されました。 |
例
例1 strspn() の例
<?php
echo strspn("foo", "o", 1, 2); // 2
?>
注意
注意: この関数はバイナリデータに対応しています。
strspn
barry dot balkowski at gmail dot com
08-Aug-2008 06:12
08-Aug-2008 06:12
B Crawford
03-Oct-2007 09:20
03-Oct-2007 09:20
This function is significantly faster for checking illegal characters than the equivalent preg_match() method.
