◎正当な理由による書き込みの削除について: 生島英之とみられる方へ:
Regular Expression(正規表現) Part17
動画、画像抽出 ||
この掲示板へ
類似スレ
掲示板一覧 人気スレ 動画人気順
このスレへの固定リンク: http://5chb.net/r/tech/1702684760/
ヒント:5chスレのurlに http://xxxx.5chb.net/xxxx のようにbを入れるだけでここでスレ保存、閲覧できます。
Regular Expressionスレです。
質問する場合は必ず実装言語や処理系ソフトウェア名を示してください。
前スレ
Regular Expression(正規表現) Part16
http://2chb.net/r/tech/1635936601/ 次スレは
>>980宜しく
テンプレ
>>2以降
スルーされにくい質問のテンプレと例
●Regular Expressionの使用環境
Java1.5
●検索か置換か?
検索
●説明
各行の1番目のAまでを検索したい
●対象データ
ABCA
BCAA
CABA
●希望する結果
ABCA
^
BCAA
^^^
CABA
^^
※ ^ はアンダーラインだそうな ^^;
>>1 乙 前スレ消化するのに2年かかってるから次スレは2025年末か
MSの.NETとMDNのJSの説明はよいけど
Perlはperlreを載せるべきじゃ
正規表現スレのテンプレにperl公式が無かったのかw
詳説 正規表現ももうだいぶ古い
近頃の正規表現エンジンが進化しすぎてもう本に全部まとめられないよね
perlの正規表現の解説だけで1冊分になってしまいそう
>スルーされにくい質問のテンプレと例
いつもスルーしてる
>非包含オペレータ
これ包茎オペに空目するからやめたほうがいいとおもう
俺すげぇ面白い事思い付いたわ
天才じゃね?
って深夜に思い付いちゃったんだろうな
異世界転生モノ好きそう
俺も思ったけど書き込まなかった
「包茎」「空目」「深夜」どこにもかかってないんだが
>9 は異世界転生モノに親でも殺されたのか流行り物が嫌いなだけなのか
どっちの方が気持ちわるいかと言えば
俺は
>>9に一票
もちろん
>>9 vs
>>10ね
以下のあぼーん用正規表現を教えて下さい
文字列3文字
文字列5文字
(空白改行)
文字列3文字
よろしくお願い致します
文字列3文字が固有の3文字なのか任意の3文字なのかがわからん
空白と空は意味がちがうから空白改行もどうとらえていいかわからん
そういう厳格さがないと正規表現は使い切れない
^ \S{3} <br> \S{5} <br> +<br> \S{3} $
>>16-17 某板に荒らしが発生しているので
荒らしレスの冒頭の
─────────────────────
>>1 岡村ほまれ
可愛い
─────────────────────をあぼーんワードにしたいのです
よろしくお願い致します
情報を小出し後出しにするやつってうざいよな
もう遅いけど使用環境を最初に示すべきだった
改行の扱いは専ブラによって違うということを知っておこう
<br>だったり\sだったりする
(?><[bB][rR]>|\r\n|[\r\n])
UPLIFT プレミアム・サービスのお知らせ
https://uplift.5ch.net/ UPLIFT 主な特典
・連続投稿の規制を緩和します。
・スレッド作成時の規制を緩和します。
・5ch.netのスレッド表示画面に表示される広告を除去します。
・5ch.net専用ブラウザで5ch.netの過去ログを閲覧できるようになります。
・海外からのアクセス・ホスト経由からでも書き込みができるようになります。
・書き込みが規制されているプロバイダーからでも書き込みができるようになります。
・5ch.netを安定して利用できるように運営を支援できます。
5ちゃんねるを存続させるためには、皆様のご協力が必要です。
最後まで御精読いただきありがとうございました。
他は無料で良いサービス提供出来てるのに金払えは甘え
5ch運営が殿様商売で無策だったツケが回って来てるだけの自業自得だから、5chなんか潰れちまえ
取り敢えずNG突っ込んだわ
このスレも役目を終えつつあるね、今時の子はこんなところには来ないと思う
yahoo掲示板にでも行ってるのかな
ChatGPTとかのAIでしょ
Yahoo掲示板こそジジイしか居ないイメージだわ
そか、AIに作ってもらえるならクレクレする必要もないね、いいことだ
そして「ChatGPTでXXをやってみたいんですがうまくいきません、どうしたら」というクレクレ質問が大量発生
あるプログラムのコーディングはすごく処理速度を意識してるのに
そのプログラムに使ってる正規表現はまったく効率を考えてない,というケースをよく見かける
正規表現をAIが作るようになれば改善されるかもね
人「おいAI、お前が作った正規表現とてつもなく遅いじゃないか」
AI「はい、ヒトが解読しやすい方が良いと判断しました。速度の問題は時が経てばマシンの性能向上で解決しますが、ヒトの解読力の方は...」
> 速度の問題は時が経てばマシンの性能向上で解決しますが
海原雄山「このポンコツAIを作ったのは誰だー」
俺にかかれば正規表現はいくらでも遅くなる
任せてくれ
.Netが正規表現エンジンを改良したと話には聞いてたけど
6年でこんなに変わるもんなんだな
Language Email(ms) URI(ms) IP(ms) Total(ms)
2018年 C# .Net Core 1952.13 1681.00 111.32 3744.45
2024年 C# .Net Core 6.46 3.79 19.35 29.59
https://github.com/golang/go/issues/26623 >>38 .Net Core(現 .Net)ってそんな前からあったっけ?
旧エンジンにマシンパワーをどれだけ積んでもネットブックで動かす新エンジンに勝てなそう
それ同じ環境と条件で比較テストしてるわけじゃないから単純にエンジンの違いによる性能差じゃないからね
正規表現は昔からあるのに未だに進化するスピードが尋常じゃないのはすごいことだ
AIの登場でこれからどうなるのか想像付かない
正規表現はオートマトンに変換するだけだから
AIとは何の関係もないぞ
高速化もこれ以上は理論的にできないし
書き方で速さが違うのは当たり前
現代の正規表現エンジンは純粋なオートマトンだけで動いているわけではないよ
例えをあげると以下の正規表現を使った検索では
[^a]+c[^b]+
まず"c"を検索して見つからなければマッチ失敗を返す
このときオートマトンは使用されないまま検索が終わる
これは実在する正規表現エンジンの動作ではなくあくまでイメージ
AIならもっと柔軟にこういう処理が出来るかも
そういう高速化はワイルドカードで
数パターンに分類してやったことはあるな
というわけで前段階で複数のワイルドカードをand/orでつなげた表記も受け付けるようにすれば
シンプルな分結構高速化できる
正規表現って現実の何かで例えるなら何?
パズル?
言語学的な感じも数学的な感じもしないような
正規表現を初めて使ったのがken氏でOnigmoもken氏
そして現代で正規表現と言えばPerl
この3つの要素を合わせるとなんと
>>51になる
AAA _ BBB _ CCC _ DDD
を
BBB AAA
にする
使用環境メモ帳
☑正規表現を使うにチェック
検索するにAAA _ BBB _ CCC _DDD
置換にBBB AAA
[A][A][A] _B{3,3} _ (C)(\1)\2 _[\x{44}][\x{44}][\x{44}]
カ)ミツカン カカ)ミツカン
の単語の始まりにある「カ)」を取ってきたいのだが、
[カ\カユユ][)\)]
だと両方ヒットする。
\b[カ\カユユ][)\)]
だと両方ヒットしない。
\bて単語の始まりじゃないの?
>>63 一般に正規表現の \b 及び \B の文脈における「単語」とは「\w+」のこと
「か」は単語ではないので、当然ながらその直前の位置(境界)に \b はマッチしない
単語の境界の単語とは\wかどうか
先頭が\w、\wと\W(又は\Wと\w)の間、最後が\w
空白も括弧も全角文字も\wではなく、全てが\Wの連続なので境界がない
(?<=^|\s| )[カ\カユユ][)\)]
こんな感じかなあ?
>>66 サンクス。
正規表現チェッカーだとうまく行くが、VBAだとエラーする。
カカ)ミツカンていう会社名なんてないから諦めるわ。
=?UTF-8?Q?=F0=9F=91=BBIt's_Halloween_Sale_=E2=80=93_Time_To_Save!?=
=?UTF-8?Q?=F0=9F=91=BBIt's_Halloween_Sale_=E2=80=93_Time_To_Save!?=
quoted-printableを切り出すのは難しいな
切り出しするのはMIMEパートで
中身はすべてQPだから難しくなさそうだけど罠がある?
こんちゃ
flexible renamerで上のフォルダを検索して、そのフォルダ名をファイル名にしたいのですが、上のフォルダの検索方法はどうすればいいんでしょうか。
../
これでいけるとおもったんですが、文字列になるみたいです
置換については \F が親フォルダ名を示すメタ文字
「サポート▶」クリックで表示されるリストを確認するといい
ところでwindowsで10の別名フォルダを同名にリネームして、中身を1つに統合みたいなことは出来ないのでしょうか?
windows ntfs union
で調べたらわかるけど困難
Linux上で実現させてそこへアクセスが単純かな
一旦同名フォルダ作って全部ぶっ込んで統合先の親に移動するだけだろ
誰もunionfsごっこやりたいとか言ってないぞ
生気表現 ('A`)
性器表現 ((i)) くコ:彡
どれがいい?
レギュラーコーヒーのレギュラーって何って質問しても満足な回答得られないから今度やってみ
レギュラーコーヒーのレギュラーはnormalとかordinaryの意味でのレギュラー
インスタントコーヒーと区別するために作られた日本語
regular expressionのregularは「規定されたルールに従った」という意味でのレギュラー
形式言語理論からの用語
>>87 >>インスタントコーヒーと区別するために作られた日本語
いわゆる「レトロニム」ってやつだね
正規表現のregularはレギュレーション的な意味?
そしてコーヒーそうだったのか
普通の王道の味のコーヒーって意味だと思ってたwww
英和だけじゃなく英英も調べるようにしたほうがいいよ
>>87 形式言語理論だと正則表現と訳すことの方が多いらしい
質問させてください
# h1
## h2
こういった構造なのですが、h2のタブ(上の例では半角スペースにしてます)を除いた箇所だけマッチさせたいです
# .*
## .*
1つ目をh1用、2つ目をh2用としてマッチさせたいのですが、これだと1つ目がh2の後半部分にもマッチしてしまいます。
対策はあるでしょうか
試したところ、後読みというは使えない環境のようでした
meryというテキストエディタです
re2のレポジトリに、ずっとコード書いてきた人を追悼するissueが立ってるけど
いたずらじゃなく本当だとしたら今後どうするんだろ
正規表現エンジンの設計ってわりと専門性高めで後任を見つけるのも簡単ではなさそうだけど
これ以上仕様ごちゃごちゃ追加しても
使いこなせる人1%もいないから放置でいいよ
Googleのre2とIntelのhyperscanは他の色んな正規表現エンジンを過去のものにした
高速な正規表現エンジンを求める人が遅い正規表現を作って使ってたりする
正規表現エンジン作者はユーザーのアップデートもしたいだろうな
そういうのはエディタの仕事だ
ビジュアライザー付き正規表現ダイアログボックスで
ミスなく正規表現を入力したらAIが改善を指摘すればよし
正規表現を作るのが下手な人は書き始める前のアルゴリズム作成の段階で
おかしくなってる場合も多い それ含め全部AIがやってくれるのが理想だ
場合抜けしてる勘違いぎみの式だけを見たって
本来の意図が何だったのかAIじゃなくて人間でもわからん場合もあるよね
正規表現だけみせても最適化しかできないだろうから
周辺のコードも与えて関数レベルで出力してもらうのが適当かもね
>>114 https?+://(?:[!-~&&[^./"()<>]]++\.)++(?!com|net|jp)(?>[a-z]{2,10})(?::(?>[0-9]{2,5}))?+(?>[/?#]|(?![!-~&&[^"()<>]]))
(?>[/?#]|(?![!-~&&[^"()<>]]))
これは先読み否定1つにまとめられる
(?!com|net|jp)
これはcomeやjpgも弾いてしまう
どちらも実用上は問題ない
前者は頭の体操にはちょうどいい難易度
アーガスで一番右に行ってから着陸しろって意味じゃね?
●Regular Expressionの使用環境
JaneXeno
●検索か置換か?
検索
●説明
ageとsageと空欄以外の文字列が含まれる場合を検出したいです
よろしくおねがいします
メール欄を検索対象にしたレス抽出ってこと?
\A(?!s?age$)
>>121 ありがとうございます
メール欄がageとsageと空欄を除き、それ以外をNGにしたいです
>>121 その正規表現だと全てNGになってしまいました・・・
>>123 ぜんぜんユーザじゃないけどbregonig.dll導入で解決しそう
>>123 (^s?age$|^$)は?
サンプルがないからよくわからんけど構造によっては空欄がムズイ気がする
^(?!sage|*age|\s|\S).*$ 前方一致否定
^(?!.*sage|*age|\s|\S).*$ 部分一致否定
^(?!.*sage$|*age|\s|\S) 後方一致否定
動くかはしらん
^(?!age).*$
^(?!sage).*$
^(?!\s).*$
を3行前方一致の否定で分けてかいてみたら?全角空白はわからん
NG Addr 正規(含まない)
^(age|sage|)$
>>124 をせんとエンジンがよわよわなだけで
正規表現は
>>121 であってるし低脳ばっかやな
datで下の3つ以外でmatchするってことだろ(書き込みエラーで<>に置き換えてる)
名前(変動)<>sage<>2024/08/22(ry
名前(変動)<>age<>2024/08/22(ry
名前(変動)<><>2024/08/22(ry
専ブラによってエンジンが違うから環境いれる気にはならんが
age sage の前後に半角空白が1つまたは2つ入ることを想定すべき
Janeの全盛期ならこんなのすぐに解決してたな
想定すべき、って言えるのなんなんだろう?
そこまで想定してなくても実用上十分、てことは多々あるだろう
スレのdatは板ごとに微妙な違いがある
半角空白が前後に入るスレは珍しくなかった
今の人が知らないのは仕方ない
>>135 それこそ想定しないても通常大丈夫なものじゃん
俺のLog漁っても20年以上前からあるけど、まだ日付けの年号が2桁でIDも付いてないものでも
前後に空白は付いてなかったくらいだ
俺はレス本体と一時期のスレタイトルぐらいしか記憶にないよ
スレタイトルは空白じゃなくてタブだったので訂正しとく
半角空白が入る板が存在しないなら対応する必要は無いよ
ただ、自分なら対応したものを作る
そういう板が1つでもあったら作り直しになるから
質問者さんが使っている板が半角空白が入る板ではないという確証が無い以上
対応しておくのが無難でしょう、したらばやJane板のような外部板のことまで考えるとね
実用上十分ってことを知らんのか
さらに、他BBSでも空白が入るところは大手ではないよ
(したらば、おーぷん、JANE総合も入らない)
大手じゃないところで半角空白が入る板があったら誤作動する正規表現を作るよりも
対応したものを作るほうがベターだと思うが
頑なに非対応にする理由もあるまい
>>133 は対応するべき、て言い切ってる
自分ならこうするとか、この方がベターとかとは一線を画す表現
やらなきゃいけないと言っている
でもさ、不特定多数に配るアプリの話じゃないんだよ?
RFC準拠のメールアドレスの正規表現はクソ長いが個人で使うのにそこまで要らん
の話思い出した
自分が使うものなら好きにすれば良いが質問の回答として正規表現を作るなら
柔軟性を確保するにこしたことはない
でないと質問者は自分じゃ直せないからちょっとした誤作動でまた質問しに来てしまう
そういう意味で「すべき」と書いたよ、何か問題ある?
> メール欄がわざと「 age 」の奴をNGできない
わざとでない「 sage」がNGになってしまうのはいいの?
試しに、名前とメール欄に前後半角空白付きで書き込んでみた
結果、datからは前後の半角空白は削除されて付いてない
そもそも、可能性があるってだけで対応しないといけないってのはおかしいだろ
たった一つだけでいいのでそういう例がある(あった)というものを出すべき
書いたところは
http://2chb.net/r/software/1724332370/204-206 それぞれJaneStyleで末尾整形あり、整形なし、汎用ブラウザ(firefox)で書いた
それは掲示板だって半角空白に対応させてるってことでしょ
正規表現で半角空白に対応しておくべきと書くことはそんなにおかしなことなの
質問者はまだ未解決のようだけどその原因が半角空白でないと言い切れる?
最初から対応しておけばこの可能性を考えずに済むよね?
なんで想定すべきと書いたらいけないの?
ここにいる人全員が納得出来る説明を求む
回答は的確に簡潔に質問に答えることがいちばん
余計な蛇足を加えて悦にいるのは自分が使う分にはいいけど人に指図するものじゃない
ソースコードやスクリプトでも質問もしてないのにあれこれ余分な配慮でコードを複雑にして
いいことをやったと自己満足してる奴にはならないようにしよう
で、半角空白が含まれるものはあるんかい
この部分は一つだけ実例を示すだけでいいんだよ
存在しえない可能性とやらを配慮するのはまったくの無駄
それは半角空白の変わりにタブコードが含まれる場合に対処しろって言うのと変わらん
>>135で板によっては存在するのは珍しくないとまでいってるんだから
そのリンクを示すだけでいいんだぞ
141がありもしない難癖ではないことを示すために
メール欄がわざと「 age 」「 sage」の例
http://2chb.net/r/software/1724332370/209-210 空白が入る板とメール欄がわざとでない「 sage」は見たことないな
^(s?age|)$でどっちもNGできるわ
>>130でもう出てる
こういう専門スレでよくある現象
質問者がいなくなったのに殴り合い始める
人のちょっとした不手際に噛みつき大騒ぎ
都合が悪いことを言われたらもっともらしいことを言ってごまかす
どこかの知事のマネかねぇ
>>147に対する
>>148の回答が面白い
>回答は的確に簡潔に質問に答えることがいちばん
と最初に書いておきながら聞かれたこととはまったく違う回答をしてる
>>123から半角空白を疑うのは自然な反応だと思うが
20年前のログがあるおっさんがキレる理由が分からんね
論破されて話題のすり替えをして逃げる卑屈な人間でいるより素直に謝ったほうがマシじゃね
てか論破されてることに気付いてなさそう
いつ変わってもおかしくないような仕様をなぜそんなに信頼できるのか
…ということを抜きにしても、「実用上十分」かどうかを勝手に決めつけるのは…
というか、
>>127 で終わりじゃだめだったのか?
次から「
>>127に帰れ」でok
向こうにも正規表現作れる人いるみたいだし
知事そっくりのおっさんはしばらく謹慎しとけ
内容的に割と単純かつどうでもいいネタに限って長引く傾向にあるな
>>126で終わってるんだよ
補足説明込みでも
>>130までで以降は無価値
>>121>>131が空気になっててかわいそうなんだが
誰か構ってやれよ
質問なのだが、htmlファイルで
<DOCTYPE からつづいて途中にあるAAAをごっそり空欄で置換したいのだが
どうやったらええん
^<DOCTYPE*AAAじゃうまくいかんかったのよねー
<DOCTYPEEEEEEEEEAAA「ぐわぁ!!
DOCTYPE*は、DOCTYPの後にEが0回以上繰りかえしているものを表すけど本当にそうなってるとは思えん
DOCTYPEEEEEEAAA
昔の仕様をごそっと<!doctype html>に統一したいなら
^<!doctype.*>で置き換えすりゃいいんじゃね、見当違いならごめん
そもそもスクリプトなのかエディタなのか
具体的な例も使用方法も書かずに答えが出るわけねえよ
回答は的確に簡潔に質問に答えることがいちばん
>>169 ^<DOCTYPE.*?AAA
通常先頭に書くDOCTYPEは
<!DOCTYPE html ~>ってなると思うんだが、!は何処に行った?
さらにAAAとか出てくるか?
AAAがdoctypeと無関係ならその間に改行も挟まってるかもしれんよ
<DOCTYPE
.*?
人に教えていいレベルじゃねぇ
シングルラインモードでフォルダ内jsonを正規表現でgrep検索できるフリーのテキストエディタ教えて
windowsで動いてGUIしっかりしてる使いやすいのがいい
外部コマンド取り込めてパスからジャンプできるエディタならなんでもいいんでは
vim/neovimとかvscodeとか
シングルラインモードと言うと複数行に渡ってマッチさせたいと?
拙者がつこうてるエディタは一行単位でしかマッチ出来なかったでござる
ワイルドカードと性器表現
どうしてこうなったマン心環境の違い
>>183 grepとエディタは別々でいいだろ
GUIのgrepソフトは外部エディタを呼べるようになってる(呼べないものって多分無い)
テキストエディタはそれこそ何でも良い
俺はDevasってgrepソフト使ってるがこれも過去に適当に探したものなのでもっといいものがあるかもしれない
いや、json限定ならjsonエディタとか使えばいいんじゃなかろうか
>>183 非ascii文字はユニコードエスケープされてる?
パーセントエスケープか
あるのとないのと両方あるしなあ
北製のエディタ選んでぶっこ抜かれてるやつはいないな?
出所の怪しいやつは避けるんだぞ?
>>184 >>187 ありがとう使ってみる
対象ファイルはUTF8で改行はLFとCF+LF混合(1ファイル内では統一)
日本語2バイト文字はエスケープなしに普通に表記されてる
>>187,193
dnGrepも良い
マッチ箇所の前後数行表示やマッチファイル全体プレビュー表示でサクッと探して
diffとtext editor用の外部コマンドラインを複数登録して使ってる
(有名どころのテンプレートあり)
>>193 テキストエディタは何でも良いとは言ったけど
起動引数にファイル名と行位置を指定できるものじゃないと使い物にならない
メモ帳はダメだが大抵大丈夫
>>194 良さそうだなと思ったらwin7には無理っぽい(.NET8だとか)
>>196 文字エンコーディング自動判別が出来るので、ちょっと古めのcp932とUTF8の混在環境で重宝すると思ったがそれは残念
>>183,193は大丈夫そうだけど(根拠なし)
pcre2の作者さんが後継者探してる
27年続けてきて最近年を感じるようになったとか
老朽ソフトウェアの後継者問題って
需要があれば勝手にメンテされるし無ければ消えるだけだよ
正規表現は時代に合ってないからこの概念ごと消えるかもしれない
>>199 正規表現が時代に合ってないってどういうこと?
たぶんだけど自然言語で書く、かな
いまでもコンパイルはしてるし
曖昧な表現だとランタイムエラーになるのはおなじ
自然言語を聞いたAIが作るのが正規表現というオチ
既存の正規表現エンジン用の正規表現ではなくAIが生成した正規表現を動かすためだけの
正規表現エンジンも生成される
既存の正規表現エンジンと比べてデータサイズが小さく不要な機能が無いため高速に動作
64コアCPUでテキストデータの64ヶ所を同時に検索
正規表現がテキストにマッチしない場合の速さが2024年時点の通常検索の速さを超えてしまう
野良猫理論: ある限られた空間であちこちをうろつく複数の野良猫が置き餌を見つけるのに
かかる時間は頭数の二乗に反比例するような気がする理論
DFA 「NFA、僕は君のことをクリーネ閉方したい」
NFA 「受理できません」
久しぶりにプログラム板にきました
あるwebサイトのたとえばx0000からx99999までのurl内それぞれ個別にあるたとえば日付等の項目を
すべてカンマ区切りで抜き出す正規表現を考えようとしましたが
結局、項目が10個まであるわけじゃないので
<!DOCTYPE.*ほにゃらら項目、ほにゃらら項目…ほにゃらら項目、ほにゃらら*</html>
てのを10まであるわけじゃない項目分それぞれ抜き出しました
本来なら、 項目,項目,項目…… で抜き出せるように一発で正規表現使えば何とかなるのでしょうけれど、
項目だけの列といいましょうかx0000の項目Aからx9999の項目Aをまずだして
次にx0000の項目Bからx9999の項目Bを次に出してと
結局その項目が10までとはいかないけれどその分をだして表計算ソフトにつっこんだわけです
結果できましたがどうにも納得がいきません
正規表現が出来ればきっとっとも楽に時間もかからずできたのでしょう
JaneXeno質問スレ9
http://2chb.net/r/software/1722559511/ いまこのスレにいたりもします。
>>207 1. まず日本語を整理する能力を身につけましょう
2. 次にテストケースを整理する能力を身につけましょう
3. そして1.と2.で身につけた能力を使ってChatGPTに問い合わせましょう
さすれば望む答えが楽に得られます
ここは野良猫理論を数学的に証明するスレになりました
頑張って2回読んだけど何のアドバイスもできそうにない
Excel VBA 質問スレ Part81
とやらにいる障害者みたいだね
DOCTYPE全然関係なかったんやな
>>180がアタリ
>>179,181はハズレ
そういえばこのスレが伸びたのも発端は
>>120だったな
>>120みたいな難問を気軽に質問されたら困る
●Regular Expressionの使用環境
VS Code 1.94.2 の検索バー
●検索か置換か?
置換
●説明
htmlファイルを開いている。
href属性が .css で終わらない場合に属性値を空文字列へ置換したい。
href="[^"]+(?!\.css)"を検索したが .css で終わっていてもマッチしてしまう。
●対象データ
<a href="URL.css">link</a>
<a href="a.html">link</a>
<link rel="stylesheet" href="a.css">
<link rel="stylesheet" href="b">
●希望する結果
<a href="URL.css">link</a>
<a href="">link</a>
<link rel="stylesheet" href="a.css">
<link rel="stylesheet" href="">
原理はよくわかりませんが自己解決しました
href="[^"]+(?<!\.css)"
href="[^"]+(?!\.css)"
<a href="URL.css">link</a>で"[^"]+の最後の文字はs
つまりsの位置では.cssではないのでマッチする
正規表現関係ないけどhtmlタグ周りの操作は
できるだけDOM経由でやっておいたほうが楽で安全だと思う
htmlの書き方がみんな揃ってるとは限らないし
<div>href="foo"</div>とかlocation.href=“bar”にはマッチしないようにするとか
いろいろ考慮ポイントが増えてミスするリスクも高くなる
DOM経由でやっておけばその辺は安心
document.querySelectorAll("[href]:not([href$='.css'])").forEach(x=>x.setAttribute("href", ""))
>>217 それ大正解だよ、すごい
それ以上のものを作れと言われたら大抵の人は悩む
というか
>>217の答えに辿り着けない人が多数かと
正規表現のオペレータの分類についての質問です
assertionにアンカーやバウンダリを含める分類はあまり見かけませんが何故でしょう?(例dotnet文書)
以下(多分regex界で著名な)参考サイトより引用
Assertions. The traditional regular expression metacharacters ^ and $ can be viewed as assertions about the text around them: ^ asserts that the previous character is a newline (or the beginning of the string), while $ asserts that the next character is a newline (or the end of the string). Perl added more assertions, like the word boundary \b, which asserts that the previous character is alphanumeric but the next is not, or vice versa.
https://swtch.com/%7Ersc/regexp/regexp1.html 確かにマッチに含まれないという意味ではよくassertionであると言われるlookback/aheadと同様です
何か含めないことで利点があるのでしょうか?
これに答えられる人はここに数人いるかどうかなのでは
(私はもちろん答えられません)
勘で答えるなら先読み、後読みは後から出てきたものなので元からあった
^ $ \b とは別物扱いになった、とかですかね?すみません、分かりません
(ゼロ幅)アサーションには含まれる、(ルックアラウンド)アサーションには含まれない
でもルックアラウンドアサーションだけを指して単にアサーションと呼ぶなんてことがあるかな、大体何か修飾語がついてるよね?
単にアサーションと呼ばれるのはゼロ幅アサーションの方だと思う
実際参考サイトもそんな感じだろう知らんけど
Google spreadsheetでREGEXREPLACE関数で置換するやり方を教えていただけないでしょうか
実行したい内容は以下の通りです。
●Regular Expressionの使用環境
Google spreadsheet
●検索か置換か?
置換
●説明
英文の各単語の先頭1文字以外をアスタリスクに置換したい
カンマとピリオドとハテナは置換しない
アポストロフィは置換する
●対象データ
Oh, it’s sunny today.
Do you understand?
●希望する結果
O*, i*** s**** t****.
D* y** u*********?
その環境がわからんので一般的な場合として
/(?<=[^ ,.?\n\r])[^ ,.?\n\r]/*/g
/(?<=[a-z’'])[a-z’']/*/ig
後読はこの関数では使えないようなのですが、関数ではなくて置換機能なら使えるようなので試してみます!
ありがとうございました!!
The problem is the ’XXX’.
こういうのはあるのかな?
>>228 正規表現のどの文法を使うかじゃなくて、どういう論理にするかを思いつくかどうかだから
(とんちクイズと一緒で発想力の問題)
なお230のようなケースがあるのならおそらく再起を使う必要がでてくると思う
>>230 これは想定していなかったですが今回はなさそうです
Apps Script使うのがシンプルなこともある
/(?<=[a-z]|[a-z]')[a-z]|(?<=[a-z])'(?=[a-z])/*/ig
(アポストロフィは半角のみにしてる)
This is the 'Tom's Home'.
→ T*** i* t** 'T**** H***'.
無理ーー
'Rock'n'Roll' is "Rock 'n' Roll". → 'R**********' i* "R*** 'n' R***".
'' is NULL strings. → '' is NULL strings.
lud20241212061719このスレへの固定リンク: http://5chb.net/r/tech/1702684760/
ヒント:5chスレのurlに http://xxxx.5chb.net/xxxx のようにbを入れるだけでここでスレ保存、閲覧できます。
TOPへ TOPへ
全掲示板一覧 この掲示板へ 人気スレ |
Youtube 動画
>50
>100
>200
>300
>500
>1000枚
新着画像
↓「Regular Expression(正規表現) Part17 」を見た人も見ています:
・Regular Expression(正規表現) Part14
・■■■レクサス LEXUS UX Part28 (正規) ■■
・■■■レクサス LEXUS UX Part21 (正規) ■■■
・『2017 PlayStation® Press Conference in Japan』9月19日(火)開催!
・【PRESIDENT Online】 「つい育ちが出てしまう」知らないと恥ずかしい"下品なお箸の持ち方" [朝一から閉店までφ★]
・【LIVE】墜落寸前!中国の天宮1号の軌道予測 April 1st, 2018 23:53 UTC ± 7 hours. that is the latest prediction.
・ロレDiffusionBrandの正規店マラソンスレ
・【正規スレ】【PS5】RDNA2X SIE次世代機卵zスレ HWRT 高速SSD アンチ出禁 83世代目 【PS5PRO】
・【中下位専用】ENGLAND Premier League 33
・SignalNow Express関連ツール[4ツール目]
・【中下位専用】ENGLAND Premier League 31
・War responsibility of Communist, Comintern
・Ali expressでこれだけは買っておけって釣具 ※中国版Amazon 世界中で大人気 [無断転載禁止]
・Aliexpress、ebay、米Amazon… 世界的通販サイトによって日本企業が徐々に淘汰されている [無断転載禁止]
・【PC】個人なら無償 インテルMac用仮想環境アプリ「VMware Fusion Player 12」 [田杉山脈★]
・【朗報】PC版"Fallout 4" 表現規制なし・Steam版の日本語対応・独自exeなしが確定
・NEC Express5800/S70 RB&PJ&SR 126本目 【鼻毛】
・NEC Express5800/S70 RB&PJ&SR 133本目【鼻毛鯖】
・NEC Express5800/S70 RB&PJ&SR 131本目 【鼻毛】
・NEC Express5800/S70 RB&PJ&SR 130本目 【鼻毛】 [無断転載禁止]
・NHK BS1 8428 (正規)
・B's DVD professional
・KING OF PRISM Session21
・【祝!パヨクに英語名定着】蓮舫民進党等研究第52弾【professional protesters】
・【努力】【期待値】リアルプロ professional2【収支】【ハイエナ】 [無断転載禁止]
・オイラのアナルはprogressive
・Slay the Spire Ascension27
・Slay the Spire Ascension18
・Slay the Spire Ascension13
・【SONY】THE世界遺産 7【PRESENTS】
・DIVISION REBEL TACKLES 7年待ち
・DIVISION REBEL TACKLES 6年待ち
・Foreign IP regulations temporarily removed.
・PHANTASY STAR ONLINE 2 NEW GENESIS【1】
・ポケモン新作発表会 Pokémon Presents 実況スレ
・詐欺まがい!マルチもどきの株式会社Presidentを野放しにするな
・ASUS ZenFone 2 Laser ZE500KL SIMフリー Part15 [無断転載禁止]
・∴ξ∵ξ∴PRESIDENT...TRUMP201611121650∵ξ∴ξ∵【本スレ】 [無断転載禁止]
・【 #立憲民主党 】 #有田芳生 氏「FUCK YOU VERY MUCH PRESIDENT TRUMP」をリツイート
・「ウイルスの発生源は中国ではない」と訴える中国のキャンペーンが再び活発に 現地調査を求めるオーストラリアに強く反発(JBpress) [Felis silvestris catus★]
・【パヨク悲報】有田芳生さんがリツイート「F○CK YOU VERY MUCH PRESIDENT TRUMP」 Part2
・ソニー IFA 2016 プレスカンファレンス(IFA 2016 Sony Press Conference) [無断転載禁止]
・Tehu君、ついに英語アピールで嫌儲民に反撃 「Presidential Debate のファクトチェック。この仕組み本当にすごい。」
・【社会】 安倍さん見て見ぬふり「実質賃金下落」「正社員カースト制度」~2014人事関連重大NEWS(前) [PRESIDENT]
・日本の安全を脅かす日本学術会議 防衛省の事業には協力しないが、人民解放軍と密接な関係にある中国企業とは協力… JBpress [Felis silvestris catus★]
・もの凄い勢いで誰かが質問に答えるスレ53http://lavender.2ch.net/test/read.cgi/siki/1496766583/ [無断転載禁止]
・Node.js + Express
・海外通販 AliExpress 98
・海外通販 AliExpress 16
・海外通販 AliExpress 80
・海外通販 AliExpress 66
・海外通販 AliExpress 84
・海外通販 AliExpress 109
・海外通販 AliExpress 83
・海外通販 AliExpress 126
・AliExpressで購入 ©bbspink.com
・海外通販 AliExpress 119
・海外通販 AliExpress 57
・海外通販 AliExpress 61
・海外通販 AliExpress 147
・海外通販 AliExpress 63
・海外通販 AliExpress 156
・海外通販 AliExpress 118
・海外通販 AliExpress 77
・海外通販 AliExpress 141
09:48:26 up 65 days, 10:47, 0 users, load average: 8.10, 8.09, 8.49
in 0.027575969696045 sec
@0.027575969696045@0b7 on 062122
|