トップページphp
986コメント301KB

正規表現道場@2ch

■ このスレッドは過去ログ倉庫に格納されています
0001ヽ(´▽`)ノ2001/07/26(木) 09:03ID:???
以外と毛嫌いして居る人も多そうな正規表現、
でもperlを使いのなす上で避けて通れない道だったりするかもです。
そこで、スクラップブック的に目に止まったカッコイイ正規表現を
書き留めておこうと言うスレッドです。
質問する時は言語と、得たい結果をなるべく詳しく書いてね。

取り合えず僕が知ってる有用なリンクです。
http://www.din.or.jp/~ohzaki/perl.htm
http://www.kt.rim.or.jp/~kbk/regex/regex.html

もっとイイ(・∀・) リンクは>>2-10さん辺りが書いてくれるカモ・・・・
0521”管理”人04202/08/03 02:59ID:???
>>520 さんは、スレッド 【Ruby】RubyでCGI   http://pc.2ch.net/test/read.cgi/php/988948655
とのマルチポストです。
速やかに回線を切って首を吊って下さい。
0522nobodyさん02/08/05 17:55ID:???
チョッチュネー、下がり過ぎッチュネー!
0523nobodyさん02/08/12 04:22ID:???
なにも言うな! あげとく。
0524nobodyさん02/08/16 21:56ID:???
すみません、「<」と「>」の間に挟まれる文字(半角英数字、記号含む)を抜き出す
というのはどうすればいいんでしょう?
0525nobodyさん02/08/16 22:11ID:???
>>524
ガイシュツ
0526nobodyたん02/08/19 12:47ID:???
@hoge = ($str =~ /<(.*?)>/g);
0527nobodyさん02/08/20 11:47ID:???
0001海
0003水着
0005スイカ
0002花火




というデータが入った配列があって
これをGrepで
0003以上(0003水着 0005スイカ)のデータを
抽出したいのですが
どのように記述してよいのかわかりません。
>= とか <= とかは正規表現では使えないですよね?

全件ループしてIF文で抽出してもよいのですが
Grepの方が速い?と思い質問させていただきました。お助け下さい。
0528nobodyさん02/08/20 11:55ID:???
@result= grep($_ gt '0003', <DATA>);
052952802/08/20 12:00ID:???
間違った
@result= grep($_ ge '0003', <DATA>);
0530nobodyさん02/08/20 17:19ID:???
>>528さん
おぅ!!!!!完璧です!!!感謝!!!!
わかると簡単だけど、最高に感謝です!!

あなたに幸がある事を祈ります!!!
本当にありがとうございました。<(..)>
0531nobodyさん02/08/26 16:09ID:???

$b =(?=.*犬)(?=.*柴):

ループ開始
 if ($a ~ /$b/){処理}
ループ終了

ある配列をループさせて $a にその値を入れて
数千回ループさせて検索しているのですが
ものすごく遅いです。

やりたい事は $aの文字列に ある文字(複数)があるかを高速に
検索したいです

もっと高速に検索する方法はないでしょうか。
ちなみに $b の部分は検索条件が何個でも対応できるようにしたいです。
どなたかお願いします、、、
0532nobodyさん02/08/26 16:36ID:???
>>531
index連呼。
0533nobodyさん02/08/27 09:53ID:???
>>532さん
index連呼ですか?
すいません。どのような意味なのでしょうか。。。

条件の数だけループして普通通り検索すると言うことでしょうか。
053453302/08/27 09:58ID:???
すいません。
文字列検索の index(STR,SUBSTR) ですね。
やはり単純にそれがよいのでしょうか。

index連呼で検索するのと
=~ // 連呼で検索するのは理論上はどちらが早いのでしょうか。
0535nobodyさん02/08/27 11:17ID:C50HKFyh
>>534
まず試せば?

$a = 'sadfasfj犬okewrworwa';#含まれない
$aa = 'sadf柴asfj犬okewrworwa';#含まれる

use Benchmark;
timethese(300000,{
1=>q{if ($a =~ /(?=.*犬)(?=.*柴)/){$c = 0;}},
2=>q{if ($aa =~ /(?=.*犬)(?=.*柴)/){$c = 0;}},
3=>q{if(index($a,'犬') >= 0 && index($a,'柴') >= 0){$c = 0;}},
4=>q{if(index($aa,'犬') >= 0 && index($aa,'柴') >= 0){$c = 0;}}
});

#Benchmark: timing 300000 iterations of 1, 2, 3, 4...
#1: 13 wallclock secs (12.53 usr + 0.00 sys = 12.53 CPU) @ 23944.45/s (n=300000)
#2: 2 wallclock secs ( 2.60 usr + 0.00 sys = 2.60 CPU) @ 115251.63/s (n=300000)
#3: 1 wallclock secs ( 0.51 usr + 0.00 sys = 0.51 CPU) @ 588235.29/s (n=300000)
#4: 0 wallclock secs ( 0.97 usr + 0.00 sys = 0.97 CPU) @ 308959.84/s (n=300000)
0536nobodyさん02/08/27 11:36ID:kyy6coMT
http://www2.freenet.jp/muneo/index.htm
超悪徳会社 J−COM(ジェイコム)の定期点検を大儀名文とした
勧誘営業に困っていませんか?
点検と言いつつ何もせず、結局はインターネット等の契約をして欲しい
の話へもっていく腐れ外道集団。
断ると「テレビの映りが悪くなっても知らんぞ」と脅迫メッセージをぶつけてくる。
苦情は総務省へ直接電話をすること。
マスコミはケーブルTVとは仲がいいので、テレビで取り上げることはまず無い。
2ちゃんねるパワーでジェイコムを追い詰めよう!!
0537優香02/08/27 18:39ID:UTh7HsUo
の記述の中で『090』を禁止語句にするにはどうしたらいいのでしょう??

elsif ($email !~ /[\w\.\-\&]+\@[\w\.\-\&]+\.[\w\.\-\&]/){&error("メールアドレスが間違っています。");}
0538nobodyたん02/08/27 20:01ID:???
とりあえず理解可能な日本語で書くように。
0539呼んだ?02/08/27 20:03ID:???
 _γ⌒⌒ヽ
 \\ノハ)ヽ)∩
  (○) ´∀`ノ丿  / ̄ ̄ ̄ ̄
  ⊂二 y /   < マルチですー。
    / _二⊃  \____
 ⊂二ノ
0540nobodyさん02/08/27 21:39ID:WUqkZoDp
>>537
まるちぃ〜ん
0541はにゃーん☆02/08/28 19:01ID:???
From: =?ISO-2022-JP?B?xxxxxxxxxxxxx=?= <xxxxx@xxxxxxx.xxx>
From: xxxxx@xxxxxxx.xxx
上記のどちらの時でもメールアドレスだけを抜き出す方法を教えてください。
また、メールのヘッダー内の「From:」や「To:」は
これ以外の形で送られるときはありますでしょうか?
例えば
From: <xxxxx@xxxxxxx.xxx> =?ISO-2022-JP?B?xxxxxxxxxxxxx=?=
の様になっていることなど...
どのような形でも確実に(無理で有ればほぼ確実に)抜き出す方法を教えてください。
よろしくお願いします。
色々と試していたのですが
/^From: .*?([\w\+\-\.]+@[\w\+\-]+\.[\w\+\.\-]+).*$/
これで思い通りに抜けるのですが問題有りますでしょうか?
0542はにゃーん☆02/08/28 19:15ID:???
大崎さんのperlメモを拝見させていただいたのですが、
下記のようでよいのでしょうか?
$mail_regex =
q{(?:[^(\040)<>@,;:".\\\\\[\]\000-\037\x80-\xff]+(?![^(\040)<>@,;:".\\\\} .
q{\[\]\000-\037\x80-\xff])|"[^\\\\\x80-\xff\n\015"]*(?:\\\\[^\x80-\xff][} .
q{^\\\\\x80-\xff\n\015"]*)*")(?:\.(?:[^(\040)<>@,;:".\\\\\[\]\000-\037\x} .
q{80-\xff]+(?![^(\040)<>@,;:".\\\\\[\]\000-\037\x80-\xff])|"[^\\\\\x80-} .
q{\xff\n\015"]*(?:\\\\[^\x80-\xff][^\\\\\x80-\xff\n\015"]*)*"))*@(?:[^(} .
q{\040)<>@,;:".\\\\\[\]\000-\037\x80-\xff]+(?![^(\040)<>@,;:".\\\\\[\]\0} .
q{00-\037\x80-\xff])|\[(?:[^\\\\\x80-\xff\n\015\[\]]|\\\\[^\x80-\xff])*} .
q{\])(?:\.(?:[^(\040)<>@,;:".\\\\\[\]\000-\037\x80-\xff]+(?![^(\040)<>@,} .
q{;:".\\\\\[\]\000-\037\x80-\xff])|\[(?:[^\\\\\x80-\xff\n\015\[\]]|\\\\[} .
q{^\x80-\xff])*\]))*};
$hoge = 'From: =?ISO-2022-JP?B?xxxxxxxxxxxxx=?= <xxxxx@xxxxxxx.xxx>';
$hoge =~ s/^From: .*?($mail_regex).*$/$mail=$1/e;
0543nobodyさん02/08/28 21:22ID:???
>>541
多少削れる部分があると思いますが、特に問題は無い様に思います。

>>542
質問内容が解りませんが。
正規表現道場ですから、マッタりと待てば誰かが解析してくれるかも知れません。
0544nobodyさん02/08/29 00:30ID:???
>>541
( ´,_ゝ`) プッ      
0545nobodyさん02/08/29 12:19ID:???
>>544 は何しにこのスレに来てるのデスカ
0546困ったヤシ02/08/29 14:55ID:???
あのぅ
すいませんが…
正規表現で困っています
『file "〜』か『FILE "〜』っていう
キーワードで検索したいんですけど
おながいしますた
0547_02/08/29 14:57ID:???
>>546
/『file "〜』|『FILE "〜』/;
0548困ったヤシ02/08/29 15:01ID:???
早速のレスですいやせんが
訂正と補足します。
grepで
from や FROM の次に半角の空白と"以外の
列を探したいのです
/[^from "]|[^FROM "]/;
では無理っぽいですた
0549nobodyさん02/08/29 15:04ID:???
>>548
/form[^ "]/i
0550困ったヤシ02/08/29 15:12ID:???
549さん
早速のレスはありがたや
なのですが…

from が form になってます…

出来ませんでした。
補足します秀丸でのgrepです

0551困ったヤシ02/08/29 15:38ID:???
/from [^"]|FROM [^"]/;
でもだめれす…
お助けを
0552nobodyさん02/08/29 15:46ID:???
秀丸なんて使ったことないよ。作ったヤシに聞けよ。秀 丸男だっけ?

っつーか、VIM使えよ
0553困ったヤシ02/08/29 15:47ID:???
VIM?
0554困ったヤシ02/08/29 16:00ID:???
教えてくださいヴぃあいえむを
0555 ◆JAPH9PWA 02/08/29 16:34ID:???
ほんとに困ったヤシだね
fileとかformとかfromとか…とりあえず言ってる意味がよくわからないので
どういうパターンなのか他人に分かるように説明してもらわないと
あと、秀丸のヘルプくらい読んでね


0556困ったヤシ02/08/29 16:38ID:???
はいどうも困ったヤシです
fromとハンカクの空白とダブルクォーテーション以外の文字のキーワード
冷)from う
冷)FROM あ
なんかにひっかかってほしいんでしゅ
どうですかぁ?お客さん
0557nobodyさん02/08/29 16:48ID:???
あのぅ
すいませんが…
正規表現で困っています
『困ったヤシ』を削除したいんですけど
s/『困ったヤシ』*?$//g;
では無理っぽいですた
0558名無しさん@Meadow02/08/29 17:12ID:???
>>556
[from|FROM] [^"]
0559名無しさん@Meadow02/08/29 17:19ID:r4ScsmNZ
>>557
s/『困ったヤシ』//g;
*?$って書くと、行末の『困ったヤシ』にしか対応線。
0560nobodyさん02/08/29 17:51ID:???
>>558
(from|FROM)[^"] デショ
0561nobodyさん02/08/29 17:53ID:???
>>560
( ´,_ゝ`) プッ   
0562困ったヤシ02/08/29 17:56ID:???
キタ━━━━━(゚∀゚)━━━━━!!!!!
(from |FROM )[^"]
で逝きますた
0563nobodyさん02/08/29 18:13ID:???
>>561
( ´,_ゝ`) プッ
056456002/08/29 18:21ID:???
その
( ´,_ゝ`) プッ
てやつやめてくれませんか。お願いします。
間違いがあるなら指摘しテク浅い。
0565nobodyさん02/08/29 18:24ID:???
( ´,_ゝ`) プッ  だってさぁ、半角スペースがどこにも入ってないから
0566nobodyさん02/08/29 18:31ID:???
( ´,_ゝ`) フーン
0567困ったヤシ02/08/29 18:32ID:???
やめなよう
揉めごとはぁ。
(´Д`)ハァハァ
0568困ったヤシ02/08/29 18:45ID:???
(´Д`)ハァハァ
0569nobodyさん02/08/29 18:47ID:???
まぁ、質問者当人が喜んでいるので万事解決って事で。
0570いらすま02/08/30 21:33ID:kfTl+oQS
性器表現

男性器→ おちんちん
女性器→ おまんこ
0571nobodyさん02/08/30 22:21ID:???
で?
0572nobodyさん02/08/30 22:29ID:???
URLで使用できる文字を教え頂きたいのですが、
英数字と;/?:@&=+$,-_.!~*'()] だと思うのですが、検索しても
見つかりませんでしたので・・・
0573nobodyさん02/08/30 23:09ID:???
%
0574名無しさん@Meadow02/08/30 23:18ID:???
>>572

perldoc -q url
0575nobodyさん02/08/31 07:19ID:OvxGQyUv
http://europa.ath.cx/content/computers/docs/o'reilly/book/
0576nobodyさん02/09/01 16:35ID:qOjuyzjx
>>572
http://openlab.ring.gr.jp/k16/htmllint/explain.html#excluded-url
0577名無しさん@Meadow02/09/04 03:47ID:zyxWHEDD
jperlも[^2バイト文字]の場合、1バイト単位で処理するんですね。
sjisでは、全角記号は、ほとんど(全部?)\x81から始まっているので、
/[^※]+/とすると全角記号が入っている場合は合致しないんです。
この理解で合っていますか。
0578 ◆dKHETt0c 02/09/04 13:06ID:???
てすと
0579nobodyたん02/09/04 13:17ID:???
>>572
ftp://ftp.iij.ad.jp/pub/rfc/rfc2396.txt
http://www.japu.org/tmp/http.c
0580nobodyさん02/09/05 01:39ID:???
2ちゃんねるのIDはこれでいいですか?
^[A-Za-z0-9/]{8}$

PHPなんですけど
0581nobodyさん02/09/05 12:34ID:qJJ4ywe1
「>」で始まってて「;」で終わっていたら、

「>」から「;」の前までの文字の色を青くして
「;」は消去したいんですが、

$hoge =~ s/(^>[.]);/<font color=blue>$1</font>/ig;

ではダメみたいです。

全角文字がいけないのか、半角のセミコロンはつかえないのか、
そもそもなにか間違ってるのかわかりません。

だれか正解を教えてください。
058258102/09/05 12:39ID:qJJ4ywe1
いろいろ間違いを見つけて

$hoge =~ s/(>.+);/<font color=blue>$1<\/font>/ig;

ここまで行きました。

まだ間違ってますか?
0583nobodyさん02/09/05 12:55ID:87M5TYG6
>>582
英文字使ってないならオプションのiはいらんだろ。
.+? か [^;]+ にしないと>の後にセミコロンが複数あった時
最後のセミコロンまでの全ての文字がマッチしちゃうぞ。

$hoge =~ s/(>[^;]+);/<font color=blue>$1<\/font>/g;

あとタグを扱う場合は区切り文字変えた方が
/のエスケープ要らなくなって見やすい。
$hoge =~ s|(>[^;]+);|<font color=blue>$1</font>|g;
0584 ◆4XfSMGTg 02/09/05 12:56ID:???
>>580-582
( ´,_ゝ`) プッ
058558102/09/05 13:46ID:qJJ4ywe1
まだだめです
>あああ >おおお;

ってやると最初の>から;まで青くなってしまいます。
>おおお;
だけ青くしたいんです。
0586nobodyさん02/09/05 13:52ID:???
>>585
あとから条件足すなボケ
058758102/09/05 13:54ID:qJJ4ywe1
$body =~ s/(>[^;^>]+);/<font color=blue>$1<\/font>/g;
すいません。わすれてました
でもこれで大丈夫のようです。

なぜか改行はいっても大丈夫(色がかわらない)のですが、なんででしょうか?
べつに変わらなくてよいのでいいんですけども、理由が気になります。
0588nobodyさん02/09/05 14:06ID:???
while (<>){
$_ =~ s/(PAT)/$1/g;
}
とか
for (@foo) {
$_ =~ s/(PAT)/$1/g;
}
してるんなら、$_には読みこんだ一行しか入ってないから。
$/ = ''でもしとけ。

つか、全然正規表現じゃねーだろ。青らくだかって勉強しろボケ。
0589nobodyさん02/09/05 14:20ID:???
>>588
あふぉですか?
0590nobodyさん02/09/05 14:21ID:87M5TYG6
>>587
それじゃダメ。
>のコードは\x81\x84なので
[^;>]は[^;\x81\x84]と等価。ちなみに^は最初に一つ置くだけでいい。
つまり;か81か84が出てきたら全て否定されるので。81か84を含むコードを
持つ文字がある場合にマッチしなくなる。

こうしれ。
$hoge =~ s|(>(?![^;]+>)[^;]+);|<font color=blue>$1</font>|g;
059158102/09/05 14:24ID:qJJ4ywe1
>>590
ありがとう!

なぜか「→」とかの記号が中に入ると
ダメになっちゃったんだよ。

そういうことか。マジでありがとう!
ちなみに改行は大丈夫でした。記号が入っていたようです。すみませんでした。
059258102/09/05 14:28ID:qJJ4ywe1
>>590
・・・なにもマッチしないんですけど・・・。

なんでだろ。
0593nobodyさん02/09/05 14:36ID:87M5TYG6
>>592
上の例だとマッチするが…
下記に確認に使ったソースを載せとく。

他に何か言い忘れてる事ある?
マッチさせたくてさせられなかった文字列はどんな?

#! /usr/local/bin/perl

print "Content-type: text/plain\n\n";

$hoge = '>あああ >おおお;';
$hoge =~ s|(>(?![^;]+>)[^;]+);|<font color=blue>$1</font>|g;

print "$hoge";
059458102/09/05 14:40ID:qJJ4ywe1
>>592
すいません
バッチリでした。
ちょっとぜんぜん関係ないところでミスってました。

本当に申し訳ありませんが、もうひとつだけ条件追加させてください。

>と;の間で改行したらマッチしないようにしたいです。
この場合の改行は<br>なので改行コードではないです。
だから簡単だと思ったのですが、「<br>」という文字列を丸ごと指定する方法が
わかりません。

こまった。
0595nobodyさん02/09/05 14:53ID:87M5TYG6
>>594
$hoge =~ s%(>(?![^;]*(?:>|<br>))[^;]*);%<font color=blue>$1</font>%ig;

どこに<br>が入ってるかわかんないので+を*に変えといた。
ので、>;でもマッチしてしまうが。
059658102/09/05 15:11ID:qJJ4ywe1
まじで感謝です
>;でマッチするのはぜんぜんOKです。

ありがとうございました!
0597nobodyさん02/09/05 16:03ID:???
2バイト目が81の文字の後に1バイト目が84の文字が続くと
>の部分にマッチしてしまう罠。
0598nobodyさん02/09/05 17:50ID:???
>>597
( ´,_ゝ`) プッ アサハカさんですね
0599nobodyさん02/09/14 03:35ID:ptF5alUd
$QUERY{'hd'}が「あ」だったら
あほ、あへへ、とかにヒットするようにしたいんですが、やり方わかりません。
if ($DB[$key] =~ /^$QUERY{'hd'}.*/) 〜
とかやってみました。ぜんぜんだめです。「{」は「\{」って書くんですか?
やってみたけどだめでした。どやってやったらいいですか。
0600名無しさん@Meadow02/09/14 08:27ID:???
>>599
条件をもっと正確に書きましょう
「あほ、あへへ、とか」って?
$DB[$key]が「あ」で始まる任意の文字列にマッチする場合ということなら
if ($DB[$key] =~ /^$QUERY{'hd'}.*/) 〜
これでええです。
エラーをもっと正確に書きましょう
「ぜんぜんだめです。」って?
エラーメッセージを見ればほとんどのことは分かるんです

0601nobodyさん02/09/14 16:49ID:???
^ はいらないんじゃない?
0602名無しさん@Meadow02/09/14 21:28ID:???
>>601
$ perl -e '$var="abc"; if ($var=~/b/){print "601 is an aho!\n";}'
601 is an aho!
0603名無しさん@Meadow02/09/14 21:30ID:???
$ perl -e '$var="abc"; if ($var=~/^b/){print "601 is an aho!\n";} else {print "
601 is God!\n";}'
601 is God!
0604nobodyさん02/09/15 00:00ID:???
>>602 がah(略
0605名無しさん@Meadow02/09/15 07:34ID:???
>>602, >>603はGod
>>604はdoah(略
0606nobodyさん02/09/16 22:01ID:l9cfV4Lx
文字列置換で置換後に\1を参照した直後に1を挿入したいのですが、\11と書いたら
だめでした。どうやって書けばいいですか。よろしくお願いします。
$error_flags = "0000000000000";
$error_flags =~ s/^(\d{1})\d{1}(\d{11})$/\11\2/g if ($QUERY{'form_v2'} eq "");
$error_flags =~ s/^(\d{2})\d{1}(\d{10})$/\11\2/g if ($QUERY{'form_v3'} eq "");
0607nobodyさん02/09/16 22:10ID:???
${1}1$2
0608nobodyさん02/09/16 22:16ID:???
おお、なるほど。そんな書き方でしたか。やってみます。
どうもありがとうございます。
0609nobodyさん02/09/17 02:24ID:QLf2zkHZ
3文字の数字のみにマッチをしているのですが、できません。

if($word=~/^[0..9]{3,3}$/){ print"ok";}

\dなど使わないでこの形式で正して下さい。
0610名無しさん@Meadow02/09/17 02:42ID:???
>>609
相当の初心者さんですね
[0-9]{3}
0611nobodyさん02/09/17 03:51ID:QLf2zkHZ
>>610
できた。できた。ありがとうございます。{3,3}でもできた。
0612nobodyさん02/09/17 08:17ID:???
>>611
>{3,3}でもできた。
そりゃできるだろうけど、「3文字の数字」を探すときにわざわざ
「3文字以上3文字以下の数字」って書くのはちょっとね。
0613nobodyさん02/09/17 09:33ID:???
少し前に、Web製作板のJavaScriptスレでも同じ質問があったな…
0614nobodyさん02/09/17 11:32ID:???
>>610
なかなかの初心者さんですね
\d\d\d
0615nobodyさん02/09/17 12:25ID:???
>>614
な(略)
\d{3}
0616名無しさん@Meadow02/09/17 12:33ID:???
>>614, >>615
不合格!!
よく問題を読みましょう.
\dを使わずにやれとある
0617nobodyさん02/09/17 12:37ID:???
なんてこっタ━━━━━(゚∀゚)━━━━━イ!!!!
0618nobodyさん02/09/18 11:38ID:???
[0-9][0-9][0-9]
0619nobodyさん02/09/18 18:06ID:???
[0123456789][0123456789][0123456789]
0620nobodyさん02/09/22 08:08ID:GGE38Iwz
初心者ですいません。

12345 や 67890 や at41n や hyrdf985 や s4r などの文字列を

12 67 at hy s4

のように先頭の2文字だけに変換させるのはどうしたらよいでしょうー。
substr使えやゴルァ といわずに、正規表現でやってみたいのです。
何文字あるのかわからないため、...$ などは使えないし。
s/^..// なんてやると2文字だけ消えてしまうし、、
$_ = '1234567';
/(^..)/;
ってやれば、$_ = $1 でできるかもしれないけど、こんな手間かけるのもアレやし、、

s/先頭の2文字でない文字//;

とかやりたいの。
■ このスレッドは過去ログ倉庫に格納されています