Perlの正規表現で条件分岐する方法
Perlの正規表現で条件分岐する方法を紹介します。
1.Perlの正規表現で条件分岐する
たとえば文字列の先頭に「"」が存在する場合、文字列の末尾に「"」が必須であるパターンと、「"」がないパターン、
"foo"
と
foo
の両方にマッチさせたい場合の正規表現は次のようになります。
^(")?(?(1)\w+"|\w+)$
サンプルコード
#!/usr/bin/perl
use strict;
use warnings;
my $str = '"aaa"';
if ( $str =~ /^(")?(?(1)\w+"|\w+)$/ ) {
print "match";
} else {
print "not match";
}
解説です。まず、
^(")?
で、先頭にダブルクォーテーション「"」が1文字(または0文字)存在することを判定します。
次に、
(?(1)
で、グループ(ここでは1)にマッチすれば真となります。つまりダブルクォーテーションが存在すれば真となります。
\w+"|\w+
そして、さきほどの結果が真であれば「\w+"」を実行し、偽であれば「\w+」を実行します。
認識誤りがあったらどこかでつぶやいてください。
下記の例では文字の並びをチェックします。
my $str = 'ATGAAG'; # GATGGC/TAGBBC
if ( $str =~ /[ATGC]+(?(?<=AA)G|C)$/ ) {
$strに設定する文字が「ATGAAG」であれば
(?<=AA)
にマッチし、「GATGGC」であれば戻り読み「(?<=AA)」にはマッチしませんが正規表現にはマッチします。
「TAGBBC」の場合は正規表現にマッチしません。
なお上記の戻り読み、あるいは先読み・コード表明の場合、次のように条件部分をカッコで囲む必要はないようです。
(?((?<=AA))G|C)
2.参考サイト
参考サイトは下記です。ありがとうございました。
Posted by yujiro このページの先頭に戻る
- Perlの正規表現で文字列マッチを繰り返し判定する方法
- 正規表現の最短マッチと最長マッチについて
- Perlの正規表現で繰り返し置換する方法
- Perlの正規表現で複数行にマッチさせる方法
- Perlの正規表現で制御文字を削除する
トラックバックURL
コメントする
greeting