PHPマニュアル/PEARマニュアル | ユーザフォーラムで議論/質問 | マニュアル検索 | ハイライト | ハイライトオフ | ポータル | php spot

preg_quote - 正規表現文字をクオートする | JavaScript入門&応用&リファレンスなら「JavaScriptist」

  

preg_quote

(PHP 4, PHP 5, PHP 7)

preg_quote正規表現文字をクオートする

説明

string preg_quote ( string $str [, string $delimiter = NULL ] )

preg_quote() は、str を引数とし、正規表現構文の特殊文字の前にバックスラッシュを挿入します。 この関数は、実行時に生成される文字列をパターンとしてマッチングを行う必要があり、 その文字列には正規表現の特殊文字が含まれているかも知れない場合に有用です。

正規表現の特殊文字は、次のものです。 . \ + * ? [ ^ ] $ ( ) { } = ! < > | : -

/ は正規表現の特殊文字ではないことに注意しましょう。

注意:

preg_quote() は、 preg_replace() などにおける $replacement 文字列に使うことを想定したものではありません。

パラメータ

str

入力文字列。

delimiter

オプションの delimiter を指定すると、 ここで指定した文字もエスケープされます。これは、PCRE 関数が使用する デリミタをエスケープする場合に便利です。/ がデリミタとしては 最も一般的に使用されています。

返り値

クォートされた (エスケープした) 文字列を返します。

変更履歴

バージョン 説明
5.3.0 - 文字がクォートされるようになりました。

例1 preg_quote() の例

<?php
$keywords 
'$40 for a g3/400';
$keywords preg_quote($keywords'/');
echo 
$keywords// \$40 for a g3\/400 を返します
?>

例2 テキスト内の単語の斜体変換

<?php
// この例では、preg_quote($word) を使って、アスタリスクが
// 正規表現での特殊な意味を帯びないようにしています

$textbody "This book is *very* difficult to find.";
$word "*very*";
$textbody preg_replace ("/" preg_quote($word'/') . "/",
                          
"<i>" $word "</i>",
                          
$textbody);
?>

注意

注意: この関数はバイナリデータに対応しています。

参考


忘却曲線を使ってこの関数を確実に記憶に残す

フォーラムで「preg_quote - 正規表現文字をクオートする」について話す
各種マニュアル: PHPマニュアル | PEARマニュアル | Smarty(英語)マニュアル | PHP-GTKマニュアル | preg_quote - 正規表現文字をクオートする」をGoogle検索
copyright © 1997-2024 PHP ドキュメント作成グループ(ライセンス). provided by php spot. マニュアル: