ColdFusion MX
目 次 > CFML リファレンス > ColdFusion 関数 > GetToken O

GetToken

delimiters パラメータ内のリストのトークンが文字列内に存在するかどうかを調べます。

文字列の index 位置で検出されたトークンの文字列。index の値が文字列内のトークンの数よりも大きい場合は空の文字列が返されます。

文字列関数

GetToken(string, index [, delimiters ])

LeftRightMidSpanExcludingSpanIncluding

パラメータ

説明

string

文字列、または文字列を含んでいる変数です。検索対象の文字列を指定します。

index

正の整数またはそれを含んでいる変数です。トークンの位置を表します。

delimiters

文字列、または文字列を含んでいる変数です。区切り文字の区切りリストです。要素は複数の文字で構成することができます。

区切り文字のデフォルトのリストは、空白文字、タブ文字、改行文字、またはそれらのコード"chr(32)"、"chr(9)"、"chr(10)" です。

リストのデフォルトの区切り文字は、カンマです。

次の例は、この関数の動作を示しています。

例 A : 次のコードを検討します。

GetToken("red,blue:;red,black,tan:;red,pink,brown:;red,three", 2, ":;")

この関数の呼び出しでは、区切り文字 ":;" を使用して、文字列から 2 番めの要素をリクエストしています。出力は次のようになります。

red,black,tan

例 B : 次のコードを検討します。

<cfset mystring = "four,"
& #chr(32)# & #chr(9)# & #chr(10)#
& ",five, nine,zero:;"
& #chr(10)#
& "nine,ten:,eleven:;twelve:;thirteen,"
& #chr(32)# & #chr(9)# & #chr(10)#
& ",four"> <cfoutput>
#mystring#<br><br> </cfoutput>

出力は次のようになります。

four,
,five, nine,zero:;
nine,ten:,eleven:;twelve:;thirteen,
,four

GetToken 関数は、明示的な空白文字、タブ文字、または改行文字をパラメータの区切り文字として認識します(空白文字を指定するコードは chr(32)、タブ文字は chr(9)、および改行文字は chr(10) となります)。

この例での文字列 mystring には、次の文字があります。

mystring に対する次の呼び出しでは、delimiters に空白は指定されていません (省略されています)。したがって、この関数では空白文字は string の区切り文字として使用されます。

<br>
<cfoutput>
GetToken(mystring, 3):#GetToken(mystring, 3)# </cfoutput><br>

このコードの出力は次のようになります。

GetToken(mystring, 3):nine,zero:;

ここでは関数によって 3 番めの区切り文字が検出され、その直前の、2 番めと 3 番めの区切り文字の間の部分文字列が返されます。この部分文字列は "nine,zero:;" です。

例 C : 次のコードを検討します。

<cfset mystring2 = "four,"
&#chr(9)# & #chr(10)#
& ",five,nine,zero:;"
& #chr(10)#
& "nine,ten:,eleven:;twelve:;thirteen,"
& #chr(9)# & #chr(10)# & ",four"> <cfoutput>
#mystring2#<br> </cfoutput>

出力は次のようになります。

four,
,five,nine,zero:;
nine,ten:,eleven:;twelve:;thirteen,
,four

次は mystring2 に対する呼び出しです。

<cfoutput>
GetToken(mystring2, 2):#GetToken(mystring2, 2)# </cfoutput>

出力は次のようになります。

GetToken(mystring2, 2):,five,nine,zero:;

ここでは関数によって 2 番めの区切り文字が検出され、その直前の、最初の区切り文字と 2 番めの区切り文字の間の部分文字列が返されます。この部分文字列は ",five,nine,zero:;" です。

<h3>GetToken の例</h3>
<cfif IsDefined("FORM.yourString")>
<!--- 区切り文字を設定 --->
<cfif FORM.yourDelimiter is not "">
      <cfset yourDelimiter = FORM.yourDelimiter>
   <cfelse>
      <cfset yourDelimiter = " ">
</cfif>
<!--- リスト内の要素の数が、返すために検索された要素の数以上であるかどうかを調べる --->
<cfif ListLen(FORM.yourString, yourDelimiter) GTE FORM.returnElement>
   <cfoutput>
   <p>"#yourDelimiter#" で区切られた #FORM.yourString# 内の
   #FORM.ReturnElement# 要素:
   <br> #GetToken(FORM.yourString, FORM.returnElement, yourDelimiter)#
   </cfoutput>
...

目 次 > CFML リファレンス > ColdFusion 関数 > GetToken O