strtok

(PHP 4, PHP 5, PHP 7, PHP 8)

strtok文字列をトークンに分割する

説明

strtok ( string $string , string $token ) : string|false

代替のシグネチャ (名前付き引数をサポートしていません):

strtok ( string $token ) : string|false

strtok() は文字列 (string) を 何らかの文字 token によって区切られている小さな文字列 (トークン) に分割します。 "This is an example string" のような文字列がある場合、 空白文字を token に指定することでこの文字列を個々の単語に分割することができます。

strtok は最初のコールの時のみ string 引数を使用することに注意してください。 strtok は、文字列のどこにいるのかの情報を保持しているため、 2回目以降のコールでは token のみを必要とします。 最初からやりなおす場合や新しい文字列をトークンに分割する場合、 初期化するために再度 string 引数を指定して strtok をコールします。 文字列は、token の文字のどれかが見つかった場合はトークンに分割されます。

パラメータ

string

より小さい文字列 (トークン) に分割する文字列。

token

string を分割する際に使用する区切り文字。

返り値

トークンを文字列で返します。 トークンがない場合は、false を返します。

例1 strtok() の例

<?php
$string 
"This is\tan example\nstring";
/* タブと改行をトークンの区切りとして使用します */
$tok strtok($string" \n\t");

while (
$tok !== false) {
    echo 
"Word=$tok<br />";
    
$tok strtok(" \n\t");
}
?>

例2 空の部分が見つかった場合の strtok() の動作

<?php
$first_token  
strtok('/something''/');
$second_token strtok('/');
var_dump($first_token$second_token);
?>

上の例の出力は以下となります。

    string(9) "something"
    bool(false)

注意

警告

この関数は論理値 false を返す可能性がありますが、false として評価される値を返す可能性もあります。 詳細については 論理値の セクションを参照してください。この関数の返り値を調べるには ===演算子 を 使用してください。

参考

  • split() - 正規表現により文字列を分割し、配列に格納する
  • explode() - 文字列を文字列により分割する