前のページ|次のページ

NOTLOWER関数

文字列から小文字でない文字を検索し、最初に検索された文字の位置を返します。

カテゴリ: 文字
制限事項: この関数は、I18Nレベル1に準拠しています。英語以外の言語を使用する場合、可能な限りI18Nレベル1の関数の使用は避けてください。特定の環境下では、I18Nレベル1の関数は、2バイト文字セット(DBCS)または複数バイト文字セット(MBCS)エンコーディングを使用すると正常に動作しない場合があります。

構文

NOTLOWER(string <, start>)

必須引数

string

検索する文字の定数、変数または式です。

オプション引数

start

検索の開始位置と検索方向を指定する整数値を使用する任意の数値定数、変数または式です。

詳細

NOTLOWER関数の結果は、有効な変換テーブルに直接依存し(TRANTAB=システムオプション (SAS各国語サポート(NLS):リファレンスガイド)を参照)、ENCODINGおよびLOCALEシステムオプションに間接的に依存します。
NOTLOWER関数は、文字列から小文字でない文字の最初の出現を検索します。対象の文字が検出されると、NOTLOWERは文字列内の該当文字の位置を返します。対象の文字が検出されない場合、NOTLOWERは値0を返します。
引数を1つのみ使用すると、NOTLOWERは文字列の先頭から検索を開始します。2つの引数を使用する場合、第2引数startの絶対値で検索の開始位置を指定します。検索方向は次のように決まります。
  • startの値が正の場合、検索は右方向に進みます。
  • startの値が負の場合、検索は左方向に進みます。
  • startの値が文字列の負の長さよりも小さい場合、文字列の末尾から検索が開始されます。
次のいずれかの条件が満たされると、NOTLOWERは値0を返します。
  • 検索文字が見つからない。
  • startの値が文字列の長さよりも大きい。
  • startの値が0になっている。

比較

NOTLOWER関数は、文字列から小文字でない文字を検索します。ANYLOWER関数は、文字列から小文字を検索します。

次の例では、NOTLOWER関数を使用して文字列から小文字でない文字を検索します。
data _null_;    
   string='Next = _n_ + 12E3;';  
   j=0;  
   do until(j=0);  
      j=notlower(string, j+1);  
      if j=0 then put +3 "That's all";  
      else do;          
         c=substr(string, j, 1);  
         put +3 j= c=;  
      end; 
   end;
run;
次の出力がログに書き込まれます。
   j=1 c=N j=5 c= j=6 c== j=7 c= j=8 c=_ j=10 c=_ j=11 c= j=12 c=+ j=13 c= j=14 c=1 j=15 c=2 j=16 c=E j=17 c=3 j=18 c=; That's all

関連項目:

関数:
前のページ|次のページ|ページの先頭へ