正規表現
■ このスレッドは過去ログ倉庫に格納されています
1正規表現
NGNG 正規表現
NGNG
NGNG
NGNG
>>397
> とはいえ、仕様があいまいすぎ。
すいません、おっしゃるとおりです。
ある単語(note)をある単語(book)に置換したいのですが、
ダブルクォートで囲まれているもの("note")は、その置換からは除外したいのです。
> 'note' はどうする? :note: は? "abc note def" は?
したがいまして、これらはとりあえず想定外で構わないので置換してしまっても構いません。
もう少し昨日の例を詳しく書きますと
NOTE,note"note"notes-note
このようなものでも
NOTE,book"note"notes-book
のようになってくれるのを期待しています。
ただ、"abc note def" これも想定外で構わないのですが
対応が可能であるのなら、私の勉強の為に教えてくださるとありがたく思います。
>>399
ありがとうございます。
>s/(?=[^"])\bnote\b(?=[^"])/book/g;
これを試してみました。
基本的にOKかなと思ったのですが、行頭、行末では置換の対象となってくれませんでした。
> とはいえ、仕様があいまいすぎ。
すいません、おっしゃるとおりです。
ある単語(note)をある単語(book)に置換したいのですが、
ダブルクォートで囲まれているもの("note")は、その置換からは除外したいのです。
> 'note' はどうする? :note: は? "abc note def" は?
したがいまして、これらはとりあえず想定外で構わないので置換してしまっても構いません。
もう少し昨日の例を詳しく書きますと
NOTE,note"note"notes-note
このようなものでも
NOTE,book"note"notes-book
のようになってくれるのを期待しています。
ただ、"abc note def" これも想定外で構わないのですが
対応が可能であるのなら、私の勉強の為に教えてくださるとありがたく思います。
>>399
ありがとうございます。
>s/(?=[^"])\bnote\b(?=[^"])/book/g;
これを試してみました。
基本的にOKかなと思ったのですが、行頭、行末では置換の対象となってくれませんでした。
NGNG
NGNG
もっと簡単にできるかもしれないけど、
s/(^|(?<=[^\w"]))note\b|\bnote($|(?=[^\w"]))/book/g;
とかは?
> ただ、"abc note def" これも想定外で構わないのですが
後ろから数えた"の個数が奇数ならマッチしないようにして、
$b =~ s/\bnote\b(?=([^"]*"[^"]*")*[^"]*$)/book/g;
とすれば、"のマッチングが保証できる範囲ではなんとかなるかも。
前からの"の個数でマッチさせようとしたら、
可変長のlook-behindは実装してないらしい。(perl 5.8)
s/(^|(?<=[^\w"]))note\b|\bnote($|(?=[^\w"]))/book/g;
とかは?
> ただ、"abc note def" これも想定外で構わないのですが
後ろから数えた"の個数が奇数ならマッチしないようにして、
$b =~ s/\bnote\b(?=([^"]*"[^"]*")*[^"]*$)/book/g;
とすれば、"のマッチングが保証できる範囲ではなんとかなるかも。
前からの"の個数でマッチさせようとしたら、
可変長のlook-behindは実装してないらしい。(perl 5.8)
NGNG
s/"note"/hogehoge/g
s/note/book/g
s/hogehoge/"note"/g
おれならこうしちゃうな。
考えんのめんどい。
s/note/book/g
s/hogehoge/"note"/g
おれならこうしちゃうな。
考えんのめんどい。
NGNG
405名無しさん@お腹いっぱい。
NGNG 質問させてください。
&にはマッチして欲しいのですが、&にはマッチして欲しくないのです。
どのように記述すればよいのでしょう。
お願いします。
&にはマッチして欲しいのですが、&にはマッチして欲しくないのです。
どのように記述すればよいのでしょう。
お願いします。
406405
NGNG &にはマッチ
&amp;にはマッチしない
でした。すいません。
&amp;にはマッチしない
でした。すいません。
NGNG
>>405
Perl5 でいい?
Perl5 でいい?
NGNG
>>405
/&(?!amp;)/
/&(?!amp;)/
NGNG
正規表現のおすすめ書って何がありますか?
NGNG
オライリーのやつ。
411名無しさん@そうだ選挙に行こう
NGNG ワイルドカード(DOS)の *.txt って、正規表現だとどう書くの?
NGNG
{(([0-9a-zA-Z]){0,})\.txt}とか半端に返してみるテスト
NGNG
[^\\/]+\.[Tt][Xx][Tx]\z とか (ry
NGNG
foo と bar 両方含む行をマッチさせたいんだけど、
awkでいうところの and演算子
% awk /foo/&&/bar/
が使える、windowsで動くgrepツールなんか教えてください。
#絞込み再検索のないGUIなgrepツールなんかイラネ
awkでいうところの and演算子
% awk /foo/&&/bar/
が使える、windowsで動くgrepツールなんか教えてください。
#絞込み再検索のないGUIなgrepツールなんかイラネ
415名無しさん@お腹いっぱい。
NGNGNGNG
NGNG
>>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
>
|が使えるツールなら、/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
>
418414
NGNG なるほど、andをorに展開すればいいのか。
しかし fooかつbarかつbazを検索、つーばあい展開すんのめんどくさいなぁ。
windowsのGUIなgrepツールは、サブフォルダも検索、とかできて
結構便利なのも歩けど、パイプとかorが使えなかったりしてイマイチ。
結局cygwinでawk使ってるけど、これもいまひとつメンドクサイ。
2chのログを検索してるだけなんだが_| ̄|○
しかし fooかつbarかつbazを検索、つーばあい展開すんのめんどくさいなぁ。
windowsのGUIなgrepツールは、サブフォルダも検索、とかできて
結構便利なのも歩けど、パイプとかorが使えなかったりしてイマイチ。
結局cygwinでawk使ってるけど、これもいまひとつメンドクサイ。
2chのログを検索してるだけなんだが_| ̄|○
NGNG
>>418
xyzzy の ggrep 辺りがいいんじゃない?
xyzzy の ggrep 辺りがいいんじゃない?
420名無しさん@お腹いっぱい。
NGNG Windows の AWKじゃだめですか?
421名無しさん@お腹いっぱい。
NGNG Perloしかないべ
422名無しさん@お腹いっぱい。
NGNG #から行末までをあらわす正規表現ってどうやればいいんでしょうか。
NGNG
#.*$
NGNG
#[^#]*$
NGNG
質問があります。
サクラエディタ(正規表現ライブラリ:BREGEXP.DLL)でCソース中のhogehogeをgrepしてた
場合に、コメント化(//)されている行だけは検索結果に表示したくないんですが、
どのような正規表現で検索すればいいでしょうか?
サクラエディタ(正規表現ライブラリ:BREGEXP.DLL)でCソース中のhogehogeをgrepしてた
場合に、コメント化(//)されている行だけは検索結果に表示したくないんですが、
どのような正規表現で検索すればいいでしょうか?
426名無しさん@お腹いっぱい。
NGNG あげ
NGNG
>>425
そのエディタよく知らないんだけど、Unix で動くの?
そのエディタよく知らないんだけど、Unix で動くの?
NGNG
スレタイだけ見て、板を確認してないんだと思われ。
NGNG
それを言うと、このスレ自体板違いな気もしなくはないが。ム板のだけで十分やん。
430425
NGNG UNIX板って知っていて質問をしましたが。
とりあえず、ム板に逝ってみます。
とりあえず、ム板に逝ってみます。
NGNG
>>430
Unix 用のソフトなの?
Unix 用のソフトなの?
NGNG
>>431
is not UNIX
is not UNIX
433名無しさん@お腹いっぱい。
NGNG 多分エディタの種類はどうでもよくて、 /\/\*.*\*\/ とか、そんな答えを期待していたと思われ
NGNG
ム板の正規表現もとんと書き込みないから、テストしてみたら
書き込めた。ここもどうなんだか、書き込んでみる。
書き込めた。ここもどうなんだか、書き込んでみる。
NGNG
ハハ*.*ハハ
436名無しさん@お腹いっぱい。
NGNG 指定文字列A 何か 指定文字列B
という何かにヒットさせるにはどういう正規表現にすればいいですか?
という何かにヒットさせるにはどういう正規表現にすればいいですか?
NGNG
438436
NGNG 自分で、
(文字列A).*{2,15}(文字列B)
とかでやってみたんですが、
マッチするのが、
指定文字列A 何か 指定文字列B
がマッチしてしまうので…
何か の部分だけを抽出しようと思ってます。
(文字列A).*{2,15}(文字列B)
とかでやってみたんですが、
マッチするのが、
指定文字列A 何か 指定文字列B
がマッチしてしまうので…
何か の部分だけを抽出しようと思ってます。
NGNG
後から取り出したい部分を()で囲む。(.*{2,15})みたいに。
440436
NGNG >>439さんの方法でも結果が変わりませんでした… 処理系が違うからかな?
とりあえず諦めて、
指定文字列A 何か 指定文字列B
をマッチさせて、指定文字列A+1文字目から 何か の文字数だけ切り取ることにします。
ありがとうございました。
とりあえず諦めて、
指定文字列A 何か 指定文字列B
をマッチさせて、指定文字列A+1文字目から 何か の文字数だけ切り取ることにします。
ありがとうございました。
NGNG
>>440
で、その処理系が何かを晒すつもりは毛頭無いわけですね?
で、その処理系が何かを晒すつもりは毛頭無いわけですね?
NGNG
>>441
ハゲには無理
ハゲには無理
444名無しさん@お腹いっぱい。
NGNG Perlの場合、
$_ = "いっぱい";
s/い/お/; # おっぱい
s/い/お/g; # おっぱお
ということでおk?
$_ = "いっぱい";
s/い/お/; # おっぱい
s/い/お/g; # おっぱお
ということでおk?
NGNG
_ ∩
( ゚∀゚)彡 おっぱい!おっぱお!
⊂彡
( ゚∀゚)彡 おっぱい!おっぱお!
⊂彡
NGNG
小学生のころ流行ったネタ
NGNG
性器表現
NGNG
ワロテモータ
NGNG
さんざん概出なのに・・・
NGNG
.*
452ウサチャソ
NGNG ↑アナルは性器じゃねーよな、とか思ってよく見ると、ドット米。
イボ痔か?
イボ痔か?
NGNG
>>452
拭き忘れたウンチだよ。きっと!
拭き忘れたウンチだよ。きっと!
454名無しさん@お腹いっぱい。
NGNG regexp
NGNG
rege*p
NGNG
正規表現で複数の単語の中に「/」があるときにヒットさせたいんですが
echo "hoge / hoge" | grep "\</\>"
でだめでした・・。だれか修正をお願いしますorz
echo "hoge / hoge" | grep "\</\>"
でだめでした・・。だれか修正をお願いしますorz
NGNG
458456
NGNG >>457
複数の単語の中で、"/"のみで構成される単語が存在する場合のみ
ヒットさせたいのです
つまり
a b c / d
上記ようなときで下記のどの事象にもヒットさせたくはないのです
// /a a/ a/a
複数の単語の中で、"/"のみで構成される単語が存在する場合のみ
ヒットさせたいのです
つまり
a b c / d
上記ようなときで下記のどの事象にもヒットさせたくはないのです
// /a a/ a/a
NGNG
NGNG
まことに勝手ながらこちらで続けさせてください
質問を改めます
やりたいことは
-----------------------
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
質問を改めます
やりたいことは
-----------------------
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
NGNG
462456
NGNG ↑修正します
修正前)上と下の違いは、前後にスペースを含む" / "が存在するか否かです
修正後)上と下の違いは、単語 / が存在するか否かです
修正前)上と下の違いは、前後にスペースを含む" / "が存在するか否かです
修正後)上と下の違いは、単語 / が存在するか否かです
NGNG
NGNG
>>462
「単語」とは?
「単語」とは?
465名無しさん@お腹いっぱい。
NGNG ブラケットの中でピリオドを入れる時ってメタキャラクタとして扱われますか?
[\w.]
と
[\w\.]
が同じ動きにになるみたいなんですけど・・・。
ちなみに、パールです。
[\w.]
と
[\w\.]
が同じ動きにになるみたいなんですけど・・・。
ちなみに、パールです。
NGNG
>>465
「みたい」じゃなくてテストコードで示してよ。
「みたい」じゃなくてテストコードで示してよ。
NGNG
どの言語の正規表現がどんな有限オートマトン使ってるという情報って
どこかにありますかねぇ。正規表現コンバータ作ろうかと思ってるのですが。。
NFA、DFAの違いぐらいは詳説正規表現の本でわかるのですが、実装ともなると。
オートマトンの変換に関してはコンパイラの本を参考にしてますが、
やはりかなりつらいものがありますね。たんに字句解析して作った方がいいのかなぁ。
どこかにありますかねぇ。正規表現コンバータ作ろうかと思ってるのですが。。
NFA、DFAの違いぐらいは詳説正規表現の本でわかるのですが、実装ともなると。
オートマトンの変換に関してはコンパイラの本を参考にしてますが、
やはりかなりつらいものがありますね。たんに字句解析して作った方がいいのかなぁ。
NGNG
普通にNFA+DFAでいいじゃん
NGNG
オブジェクト指向正規表現の仕様策定はまだですか?
NGNG
NGNG
>>469
まかせた。
まかせた。
472名無しさん@お腹いっぱい。
NGNG お前ら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つのコレクションが取得できるの?
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つのコレクションが取得できるの?
473472
NGNG *? つーのは最短一致という便利なキーワードなのか。
つまらん質問失礼しますた。
つまらん質問失礼しますた。
474名無しさん@お腹いっぱい。
NGNG 下がってるので、どれ一つ、とんちでも。
rubyでは
/aa+??/ =~ "a" => 0
emacsでは
"aa+??" =~ "a" => nil
さて、こうなってしまうのは、各々がどのようなオートマトンで
解釈されているからでしょうか。
rubyでは
/aa+??/ =~ "a" => 0
emacsでは
"aa+??" =~ "a" => nil
さて、こうなってしまうのは、各々がどのようなオートマトンで
解釈されているからでしょうか。
NGNG
emacsって最短マッチあんの?
NGNG
ありましゅよー
ttp://www.cs.huji.ac.il/support/emacs/elisp-help/elisp-manref/elisp_34.html
でも、{m,n}? の最短マッチはないみたい…。
ttp://www.cs.huji.ac.il/support/emacs/elisp-help/elisp-manref/elisp_34.html
でも、{m,n}? の最短マッチはないみたい…。
NGNG
最短マッチに対応した grep ってある?
NGNG
>>477
grep が最短マッチに対応してるかどうかが問題になるケースってある?
grep が最短マッチに対応してるかどうかが問題になるケースってある?
05/01/30 22:46:31
[^ま]*まってかくのめんどくさい
480名無しさん@お腹いっぱい。
05/02/26 05:47:57 あげ
481名無しさん@お腹いっぱい。
2005/03/30(水) 02:33:49 up
2005/04/19(火) 17:08:07
正規表現の実装っていろいろあることにやっと気づいた漏れorz
2005/05/14(土) 15:12:25
ほしゅ
484名無しさん@お腹いっぱい。
2005/05/16(月) 16:51:45 abc xyzをaxbyczにしたいのですが
2005/05/16(月) 17:05:02
s/abc xyz/axbycz/g
2005/05/16(月) 19:33:57
ワロタ
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/%//;"
echo abc xyz |sed -e "s/^/%/; :ll; s/[%]\(.\)\(.*\) \(.\)\(.*\)/\1\3%\2 \4/; tll; s/%//;"
2005/05/18(水) 00:13:40
うひょー
2005/05/28(土) 03:19:18
うに厨として、% をめぐる動きに溜息出た…真剣にありがと 何重にも目が覚めた
2005/05/28(土) 05:32:41
abc xyz でも
abcdefg ABCDEFG でもできるね。すげーや。
abcdefg ABCDEFG でもできるね。すげーや。
2005/06/04(土) 23:07:23
('A`)
2005/06/19(日) 02:53:08
Onigurumaを使っているんですが、
あるテキストデータがあります。
----- ここから
END
注釈 ○○○
注意 △△△
補足 ◎◎◎
TITLE
----- ここまで
という部分の、ENDの後の空白行からTITLEの前の空白行の部分(間の行)を削除して、
ENDとTITLEの間は1行だけの空白行にしたいです。
「END\s^[0-9a-zA-Z。-゜ぁ-んァ-ヶ亜-?]*\sTITLE」を指定してもマッチしないんですが、
これは私の正規表現の式が間違えているんでしょうか?
(複数行を1度に選択する方法を間違えている???)
あるテキストデータがあります。
----- ここから
END
注釈 ○○○
注意 △△△
補足 ◎◎◎
TITLE
----- ここまで
という部分の、ENDの後の空白行からTITLEの前の空白行の部分(間の行)を削除して、
ENDとTITLEの間は1行だけの空白行にしたいです。
「END\s^[0-9a-zA-Z。-゜ぁ-んァ-ヶ亜-?]*\sTITLE」を指定してもマッチしないんですが、
これは私の正規表現の式が間違えているんでしょうか?
(複数行を1度に選択する方法を間違えている???)
2005/06/19(日) 03:13:31
2005/07/13(水) 09:25:56
素直に、
~s/END(\s*.*?\s*)TITLE/END\n\nTITLE/sg;
じゃダメ?
~s/END(\s*.*?\s*)TITLE/END\n\nTITLE/sg;
じゃダメ?
2005/07/13(水) 13:15:24
>>496
Oniguruma の質問なわけだが?
Oniguruma の質問なわけだが?
2005/07/13(水) 17:54:26
…とは思ったのだが、Perl 互換らしーから、いーかなとw
てか、見つかるのむちゃくちゃ早いなww
事後ながら、oniguruma (ライブラリ)取りに行った
てか、見つかるのむちゃくちゃ早いなww
事後ながら、oniguruma (ライブラリ)取りに行った
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 【工作員】「X」のアカウント所在地公開機能が暴いた世論操作の実態 MAGA支持著名アカウントの多くが米国外から運営 日本にも波及 ★2 [ごまカンパチ★]
- 【大阪】日本一高い観覧車が落雷で緊急停止 約20人乗客が閉じ込められ9時間にわたり救助活動 [七波羅探題★]
- 【・(ェ)・】「くまちゃんがいた」散歩中の2歳園児が発見 クリ林に1頭のクマ…保育士「ワンちゃんだね…」と声かけて移動 [Ailuropoda melanoleuca★]
- ラピダス、第2工場建設でも見えぬ顧客 技術開発も難題山積 [蚤の市★]
- 【大阪】「もっとこっち来てよ」女子高校生を電車内に連れ込み 小学校教諭再逮捕「話をしたかっただけ [七波羅探題★]
- 【芸能】安達祐実 44歳の最新姿「ぇーーーーー!!!」「声出た」「なんなの」「まって」「ワオ」 [湛然★]
- 🖐( -᷄ὢ)これから>>2の>>3なんで……
- 【悲報】日本の田舎、もう住める場所じゃないと話題に
- えっ?肉離れって菜食主義の事じゃないの?俺ずっと
- 30才がJK好きなのってロリコン?
- 人間関係って続く前提で考えたほうが良いよな
- ユニクロしゃちょーってなんか影薄いよね
