[表示 : 全て 最新50 1-99 101- 201- 301- 401- 501- 601- 701- 801- 2chのread.cgiへ]
Update time : 02/03 08:16 / Filesize : 179 KB / Number-of Response : 834
[このスレッドの書き込みを削除する]
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧] [類似スレッド一覧]


↑キャッシュ検索、類似スレ動作を修正しました、ご迷惑をお掛けしました

正規表現



1 名前:正規表現 mailto:正規表現 [02/12/06 18:09]
正規表現

402 名前:名無しさん@お腹いっぱい。 mailto:sage [04/03/31 07:45]
もっと簡単にできるかもしれないけど、
s/(^|(?<=[^\w"]))note\b|\bnote($|(?=[^\w"]))/book/g;
とかは?

> ただ、"abc note def" これも想定外で構わないのですが

後ろから数えた"の個数が奇数ならマッチしないようにして、
$b =~ s/\bnote\b(?=([^"]*"[^"]*")*[^"]*$)/book/g;
とすれば、"のマッチングが保証できる範囲ではなんとかなるかも。
前からの"の個数でマッチさせようとしたら、
可変長のlook-behindは実装してないらしい。(perl 5.8)


403 名前:名無しさん@お腹いっぱい。 mailto:sage [04/03/31 14:53]
s/"note"/hogehoge/g
s/note/book/g
s/hogehoge/"note"/g
おれならこうしちゃうな。
考えんのめんどい。

404 名前:名無しさん@お腹いっぱい。 mailto:sage [04/04/01 01:10]
>>402

ありがとうございました。
たいへん勉強になりました。


405 名前:名無しさん@お腹いっぱい。 [04/04/07 15:07]
質問させてください。

&にはマッチして欲しいのですが、&にはマッチして欲しくないのです。

どのように記述すればよいのでしょう。

お願いします。

406 名前:405 [04/04/07 15:09]
&にはマッチ
&amp;にはマッチしない

でした。すいません。

407 名前:名無しさん@お腹いっぱい。 mailto:sage [04/04/07 15:26]
>>405
Perl5 でいい?

408 名前:名無しさん@お腹いっぱい。 mailto:sage [04/04/07 15:32]
>>405
/&(?!amp;)/

409 名前:名無しさん@お腹いっぱい。 mailto:sage [04/04/11 13:22]
正規表現のおすすめ書って何がありますか?

410 名前:名無しさん@お腹いっぱい。 mailto:sage [04/04/11 14:13]
オライリーのやつ。



411 名前:名無しさん@そうだ選挙に行こう [04/07/11 16:49]
ワイルドカード(DOS)の *.txt って、正規表現だとどう書くの?

412 名前:名無しさん@お腹いっぱい。 mailto:sage [04/07/11 20:35]
{(([0-9a-zA-Z]){0,})\.txt}とか半端に返してみるテスト

413 名前:名無しさん@お腹いっぱい。 mailto:sage [04/07/11 20:46]
[^\\/]+\.[Tt][Xx][Tx]\z とか (ry

414 名前:名無しさん@お腹いっぱい。 mailto:sage [04/07/11 22:41]
foo と bar 両方含む行をマッチさせたいんだけど、
awkでいうところの and演算子
% awk /foo/&&/bar/
が使える、windowsで動くgrepツールなんか教えてください。

#絞込み再検索のないGUIなgrepツールなんかイラネ

415 名前:名無しさん@お腹いっぱい。 [04/07/11 23:39]
>>412,413
. 記号は \ でエスケープになるのですね。.*\.txt でマッチはしました。
助かりました、ありがとうです。

416 名前:名無しさん@お腹いっぱい。 mailto:sage [04/07/12 22:46]
>>414

FIND "foo" | FIND "bar"

みたいのじゃ駄目?

417 名前:名無しさん@お腹いっぱい。 mailto:sage [04/07/14 00:51]
>>414
|が使えるツールなら、/foo.*bar|bar.*foo/とかで近似できるんじゃないの。
CygwinのGNU grepで試してみた。

> cat foobar.txt
foo
bar
foo foo
foo bar
bar bar
bar foo
> grep -n "foo.*bar\|bar.*foo" foobar.txt
4:foo bar
6:bar foo
>

418 名前:414 mailto:sage [04/07/23 03:17]
なるほど、andをorに展開すればいいのか。
しかし fooかつbarかつbazを検索、つーばあい展開すんのめんどくさいなぁ。

windowsのGUIなgrepツールは、サブフォルダも検索、とかできて
結構便利なのも歩けど、パイプとかorが使えなかったりしてイマイチ。

結局cygwinでawk使ってるけど、これもいまひとつメンドクサイ。
2chのログを検索してるだけなんだが_| ̄|○

419 名前:名無しさん@お腹いっぱい。 mailto:sage [04/07/29 01:12]
>>418
xyzzy の ggrep 辺りがいいんじゃない?

420 名前:名無しさん@お腹いっぱい。 [04/07/30 00:18]
Windows の AWKじゃだめですか?



421 名前:名無しさん@お腹いっぱい。 [04/08/03 09:48]
Perloしかないべ


422 名前:名無しさん@お腹いっぱい。 [04/08/06 22:51]
#から行末までをあらわす正規表現ってどうやればいいんでしょうか。

423 名前:名無しさん@お腹いっぱい。 mailto:sage [04/08/06 23:22]
#.*$

424 名前:名無しさん@お腹いっぱい。 mailto:sage [04/08/12 15:32]
#[^#]*$

425 名前:名無しさん@お腹いっぱい。 mailto:sage [04/08/24 00:25]
質問があります。

サクラエディタ(正規表現ライブラリ:BREGEXP.DLL)でCソース中のhogehogeをgrepしてた
場合に、コメント化(//)されている行だけは検索結果に表示したくないんですが、
どのような正規表現で検索すればいいでしょうか?


426 名前:名無しさん@お腹いっぱい。 [04/08/24 01:48]
あげ

427 名前:名無しさん@お腹いっぱい。 mailto:sage [04/08/24 01:56]
>>425
そのエディタよく知らないんだけど、Unix で動くの?

428 名前:名無しさん@お腹いっぱい。 mailto:sage [04/08/24 13:36]
スレタイだけ見て、板を確認してないんだと思われ。

429 名前:名無しさん@お腹いっぱい。 mailto:sage [04/08/24 13:43]
それを言うと、このスレ自体板違いな気もしなくはないが。ム板のだけで十分やん。

430 名前:425 [04/08/24 21:24]
UNIX板って知っていて質問をしましたが。
とりあえず、ム板に逝ってみます。



431 名前:名無しさん@お腹いっぱい。 mailto:sage [04/08/24 21:38]
>>430
Unix 用のソフトなの?

432 名前:名無しさん@お腹いっぱい。 mailto:sage [04/08/24 22:51]
>>431
is not UNIX

433 名前:名無しさん@お腹いっぱい。 [04/08/24 23:41]
多分エディタの種類はどうでもよくて、 /\/\*.*\*\/ とか、そんな答えを期待していたと思われ


434 名前:名無しさん@お腹いっぱい。 mailto:sage [04/09/05 06:33]
ム板の正規表現もとんと書き込みないから、テストしてみたら
書き込めた。ここもどうなんだか、書き込んでみる。

435 名前:名無しさん@お腹いっぱい。 mailto:sage [04/09/06 18:18]
ハハ*.*ハハ

436 名前:名無しさん@お腹いっぱい。 [04/09/07 16:51]
指定文字列A 何か 指定文字列B
という何かにヒットさせるにはどういう正規表現にすればいいですか?

437 名前:名無しさん@お腹いっぱい。 mailto:sage [04/09/07 17:18]
>>436
素で答えると「文字列A.*文字列B」だけど?そういう話?

もちろん文字列ABに特殊記号があったらどうするかとか、
.*は最長マッチでいいのとか、いろいろ細かい話はあるけど。

438 名前:436 [04/09/07 17:21]
自分で、
(文字列A).*{2,15}(文字列B)
とかでやってみたんですが、
マッチするのが、
指定文字列A 何か 指定文字列B
がマッチしてしまうので…

何か の部分だけを抽出しようと思ってます。

439 名前:名無しさん@お腹いっぱい。 mailto:sage [04/09/07 17:55]
後から取り出したい部分を()で囲む。(.*{2,15})みたいに。

440 名前:436 [04/09/08 01:37]
>>439さんの方法でも結果が変わりませんでした… 処理系が違うからかな?

とりあえず諦めて、
指定文字列A 何か 指定文字列B
をマッチさせて、指定文字列A+1文字目から 何か の文字数だけ切り取ることにします。

ありがとうございました。



441 名前:名無しさん@お腹いっぱい。 mailto:sage [04/09/08 02:28]
>>440
で、その処理系が何かを晒すつもりは毛頭無いわけですね?

442 名前:名無しさん@お腹いっぱい。 mailto:sage [04/09/08 10:13]
>>441
ハゲには無理

443 名前:436 mailto:sage [04/09/08 11:58]
何度もすいません。

C#です… 改めてやってみると>>439さんの方法でいけました。
group[1]に入ってたんですね。全体しか見てませんでした。

板違いにお騒がせしました。

444 名前:名無しさん@お腹いっぱい。 [04/09/10 00:33]
Perlの場合、

$_ = "いっぱい";
s/い/お/;          # おっぱい
s/い/お/g;         # おっぱお

ということでおk?

445 名前:名無しさん@お腹いっぱい。 mailto:sage [04/09/10 02:41]
  _  ∩
( ゚∀゚)彡 おっぱい!おっぱお!
 ⊂彡


446 名前:名無しさん@お腹いっぱい。 mailto:sage [04/09/10 15:00:12]
小学生のころ流行ったネタ

447 名前:名無しさん@お腹いっぱい。 mailto:sage [04/09/27 06:28:21]
性器表現

448 名前:名無しさん@お腹いっぱい。 mailto:sage [04/09/27 09:23:16]
ワロテモータ

449 名前:名無しさん@お腹いっぱい。 mailto:sage [04/09/27 11:29:59]
さんざん概出なのに・・・

450 名前: mailto:sage [04/10/13 14:29:29]





451 名前:名無しさん@お腹いっぱい。 mailto:sage [04/10/13 14:50:43]
.*

452 名前:ウサチャソ mailto:sage bill@microsoft.com [04/10/29 21:49:31]
↑アナルは性器じゃねーよな、とか思ってよく見ると、ドット米。
イボ痔か?

453 名前:名無しさん@お腹いっぱい。 mailto:sage [04/10/30 20:30:37]
>>452
拭き忘れたウンチだよ。きっと!

454 名前:名無しさん@お腹いっぱい。 [04/11/10 15:37:24]
regexp

455 名前:名無しさん@お腹いっぱい。 mailto:sage [04/11/26 21:14:34]
rege*p

456 名前:名無しさん@お腹いっぱい。 mailto:sage [04/12/16 23:14:21]
正規表現で複数の単語の中に「/」があるときにヒットさせたいんですが

echo "hoge / hoge" | grep "\</\>"

でだめでした・・。だれか修正をお願いしますorz


457 名前:名無しさん@お腹いっぱい。 mailto:sage [04/12/16 23:50:35]
>>456
条件をもっと明確に定義しろ。
マルチすんな。

458 名前:456 mailto:sage [04/12/17 00:16:01]
>>457

複数の単語の中で、"/"のみで構成される単語が存在する場合のみ
ヒットさせたいのです

つまり
a b c / d
上記ようなときで下記のどの事象にもヒットさせたくはないのです
// /a a/ a/a



459 名前:名無しさん@お腹いっぱい。 mailto:sage [04/12/17 01:22:18]
>>456
pc5.2ch.net/test/read.cgi/linux/1101654885/957
とこっちと、どっちで続けるのかね。

460 名前:名無しさん@お腹いっぱい。 mailto:sage [04/12/17 11:17:13]
まことに勝手ながらこちらで続けさせてください
質問を改めます
やりたいことは
-----------------------
1) echo "/" | grep ......
2) echo "/ a b" | grep ......
3) echo "a b /" | grep ......
4) echo "/a / b/" | grep ......
-----------------------
上ですべてマッチさせて
以下はすべてはじくようにしたいのです
-----------------------
5) echo "//" | grep ......
6) echo "// /// ////" | grep ......
7) echo "/a b/ /c/" | grep ......
-----------------------
上と下の違いは、前後にスペースを含む" / "が存在するか否かです

よって以下のように考えましたが、ヒットしませんでした
echo "a / b"|grep "\</\>"
echo "a / b"|grep "\<\/\>"

どなたか修正をおねがいしますorz




461 名前:名無しさん@お腹いっぱい。 mailto:sage [04/12/17 11:22:35]
>>460
grep と言ってもいろいろあるんだが
どの OS のどの grep よ。

462 名前:456 mailto:sage [04/12/17 11:23:16]
↑修正します

修正前)上と下の違いは、前後にスペースを含む" / "が存在するか否かです

修正後)上と下の違いは、単語 / が存在するか否かです

463 名前:名無しさん@お腹いっぱい。 mailto:sage [04/12/17 11:27:31]
>>460
> 上と下の違いは、前後にスペースを含む" / "が存在するか否かです
1) と 2) には存在しないようだが。

464 名前:名無しさん@お腹いっぱい。 mailto:sage [04/12/17 11:28:10]
>>462
「単語」とは?

465 名前:名無しさん@お腹いっぱい。 [04/12/18 00:00:37]
ブラケットの中でピリオドを入れる時ってメタキャラクタとして扱われますか?

[\w.]

[\w\.]
が同じ動きにになるみたいなんですけど・・・。

ちなみに、パールです。


466 名前:名無しさん@お腹いっぱい。 mailto:sage [04/12/18 02:48:16]
>>465
「みたい」じゃなくてテストコードで示してよ。

467 名前:名無しさん@お腹いっぱい。 mailto:sage [04/12/18 08:58:34]
どの言語の正規表現がどんな有限オートマトン使ってるという情報って
どこかにありますかねぇ。正規表現コンバータ作ろうかと思ってるのですが。。

NFA、DFAの違いぐらいは詳説正規表現の本でわかるのですが、実装ともなると。
オートマトンの変換に関してはコンパイラの本を参考にしてますが、
やはりかなりつらいものがありますね。たんに字句解析して作った方がいいのかなぁ。

468 名前:名無しさん@お腹いっぱい。 mailto:sage [04/12/18 09:16:42]
普通にNFA+DFAでいいじゃん

469 名前:名無しさん@お腹いっぱい。 mailto:sage [04/12/21 02:13:26]
オブジェクト指向正規表現の仕様策定はまだですか?

470 名前:名無しさん@お腹いっぱい。 mailto:sage [04/12/21 14:44:45]
>>469
聞いたことないな。
何それ?



471 名前:名無しさん@お腹いっぱい。 mailto:sage [04/12/21 19:26:19]
>>469
まかせた。

472 名前:名無しさん@お腹いっぱい。 [04/12/22 19:35:55]
お前らWinの.NETなんだが正規表現の質問をさせてくれ。

RegularExpressions.Regexで下の文字列を検索して<TD>から</TD>に分けたい。

string strHtml = "<TD>a</TD><TD>b</TD><TD>c</TD>"

Regex regex = Regex("<TD>.*</TD>");
MatchCollection matchcollection = regex.Matches(strHtml);

だと最長一致で "<TD>a</TD><TD>b</TD><TD>c</TD>"の1つのコレクション取得。

Regex regex = Regex("<TD>.*?</TD>");

だとやりたい "<TD>a</TD>", "<TD>b</TD>","<TD>c</TD>"の3つのコレクションが取得できる。

.*? の意味をアフォにも分かるように説明してくれ。
.*(任意の0文字以上)が?(あるかないか)だろ。
なんで思った通りに3つのコレクションが取得できるの?

473 名前:472 [04/12/22 19:38:29]
*? つーのは最短一致という便利なキーワードなのか。
つまらん質問失礼しますた。

474 名前:名無しさん@お腹いっぱい。 [05/01/07 22:21:40]
下がってるので、どれ一つ、とんちでも。
rubyでは
/aa+??/ =~ "a" => 0
emacsでは
"aa+??" =~ "a" => nil
さて、こうなってしまうのは、各々がどのようなオートマトンで
解釈されているからでしょうか。

475 名前:名無しさん@お腹いっぱい。 mailto:sage [05/01/08 07:36:53]
emacsって最短マッチあんの?

476 名前:名無しさん@お腹いっぱい。 mailto:sage [05/01/08 11:15:48]
ありましゅよー
ttp://www.cs.huji.ac.il/support/emacs/elisp-help/elisp-manref/elisp_34.html

でも、{m,n}? の最短マッチはないみたい…。

477 名前:名無しさん@お腹いっぱい。 mailto:sage [05/01/11 11:11:46]
最短マッチに対応した grep ってある?

478 名前:名無しさん@お腹いっぱい。 mailto:sage [05/01/11 13:31:51]
>>477
grep が最短マッチに対応してるかどうかが問題になるケースってある?

479 名前:名無しさん@お腹いっぱい。 mailto:sage [05/01/30 22:46:31 ]
[^ま]*まってかくのめんどくさい

480 名前:名無しさん@お腹いっぱい。 [05/02/26 05:47:57 ]
あげ



481 名前:名無しさん@お腹いっぱい。 [2005/03/30(水) 02:33:49 ]
up

482 名前:名無しさん@お腹いっぱい。 mailto:ほしゅsage [2005/04/19(火) 17:08:07 ]
正規表現の実装っていろいろあることにやっと気づいた漏れorz

483 名前:名無しさん@お腹いっぱい。 mailto:sage [2005/05/14(土) 15:12:25 ]
ほしゅ

484 名前:名無しさん@お腹いっぱい。 [2005/05/16(月) 16:51:45 ]
abc xyzをaxbyczにしたいのですが

485 名前:名無しさん@お腹いっぱい。 mailto:sage [2005/05/16(月) 17:05:02 ]
s/abc xyz/axbycz/g

486 名前:名無しさん@お腹いっぱい。 mailto:sage [2005/05/16(月) 19:33:57 ]
ワロタ


487 名前:名無しさん@お腹いっぱい。 mailto:sage [2005/05/16(月) 19:34:25 ]
保守

488 名前:名無しさん@お腹いっぱい。 [2005/05/17(火) 22:45:20 ]
>>484
echo abc xyz |sed -e "s/^/%/; :ll; s/[%]\(.\)\(.*\) \(.\)\(.*\)/\1\3%\2 \4/; tll; s/%//;"

489 名前:名無しさん@お腹いっぱい。 mailto:sage [2005/05/18(水) 00:13:40 ]
うひょー

490 名前:名無しさん@お腹いっぱい。 mailto:ほしゅsage [2005/05/28(土) 03:19:18 ]
うに厨として、% をめぐる動きに溜息出た…真剣にありがと 何重にも目が覚めた



491 名前:名無しさん@お腹いっぱい。 mailto:sage [2005/05/28(土) 05:32:41 ]
abc xyz でも
abcdefg ABCDEFG でもできるね。すげーや。

492 名前: ◆2fmGY.thDg mailto:sage [2005/06/02(木) 22:17:25 ]
a

493 名前:名無しさん@お腹いっぱい。 mailto:sage [2005/06/04(土) 23:07:23 ]
('A`)

494 名前:名無しさん@お腹いっぱい。 mailto:sage [2005/06/19(日) 02:53:08 ]
Onigurumaを使っているんですが、
あるテキストデータがあります。
----- ここから
END

注釈 ○○○
注意 △△△
補足 ◎◎◎

TITLE
----- ここまで
という部分の、ENDの後の空白行からTITLEの前の空白行の部分(間の行)を削除して、
ENDとTITLEの間は1行だけの空白行にしたいです。
「END\s^[0-9a-zA-Z。-゜ぁ-んァ-ヶ亜-?]*\sTITLE」を指定してもマッチしないんですが、
これは私の正規表現の式が間違えているんでしょうか?
(複数行を1度に選択する方法を間違えている???)

495 名前:名無しさん@お腹いっぱい。 mailto:sage [2005/06/19(日) 03:13:31 ]
>>494
つーか、正規表現だけ見せられても判断できないと思うんだけど。
改行処理や文字コードのオプション設定はどうしてるかとかいろいろ情報が足りない。

496 名前:名無しさん@お腹いっぱい。 mailto:ほしゅsage [2005/07/13(水) 09:25:56 ]
素直に、
~s/END(\s*.*?\s*)TITLE/END\n\nTITLE/sg;
じゃダメ?

497 名前:名無しさん@お腹いっぱい。 mailto:sage [2005/07/13(水) 13:15:24 ]
>>496
Oniguruma の質問なわけだが?

498 名前:名無しさん@お腹いっぱい。 mailto:ほしゅsage [2005/07/13(水) 17:54:26 ]
…とは思ったのだが、Perl 互換らしーから、いーかなとw

てか、見つかるのむちゃくちゃ早いなww
事後ながら、oniguruma (ライブラリ)取りに行った

499 名前:名無しさん@お腹いっぱい。 mailto:sage [2005/07/13(水) 19:58:46 ]
>>498
> 見つかるのむちゃくちゃ早いなww
どういうこと?


500 名前:名無しさん@お腹いっぱい。 mailto:sage [2005/07/17(日) 23:17:41 ]
>494
> 「END\s^[0-9a-zA-Z。-゜ぁ-んァ-ヶ亜-?]*\sTITLE」を指定してもマッチしないんですが、
> これは私の正規表現の式が間違えているんでしょうか?
> (複数行を1度に選択する方法を間違えている???)

これのどこが、複数行を一度に選択しているの?




501 名前:名無しさん@お腹いっぱい。 mailto:sage [2005/07/19(火) 19:22:13 ]
>>500
ONIG_OPTION_MULTILINE (や REG_NEWLINE や RE_OPTION_MULTILINE など) をセット
しているかどうかで複数行選択できるかどうか変わるので、
そのへんを晒せばもうちょっと状況がわかると思うのだが、
元質問者はもう既にどっかいっちゃったのだろうな。

502 名前:名無しさん@お腹いっぱい。 [2005/09/21(水) 20:57:28 ]
正規表現で
○○ か ○○の場合と言うのはどう表現するのでしょうか?

Cで言う、 || のようなものです。






[ 続きを読む ] / [ 携帯版 ]

前100 次100 最新50 [ このスレをブックマーク! 携帯に送る ] 2chのread.cgiへ
[+板 最近立ったスレ&熱いスレ一覧 : +板 最近立ったスレ/記者別一覧]( ´∀`)<179KB

read.cgi ver5.27 [feat.BBS2 +1.6] / e.0.2 (02/09/03) / eucaly.net products.
担当:undef