[過去ログ] Regular Expression(正規表現) Part16 (1002レス)
上下前次1-新
このスレッドは過去ログ倉庫に格納されています。
次スレ検索 歴削→次スレ 栞削→次スレ 過去ログメニュー
518(1): 2022/09/13(火)22:46 ID:7uE/UK4/(1) AAS
010001
519(1): 2022/09/13(火)23:08 ID:G28B9gdh(2/4) AAS
>>513
> 文中(先頭及び文末以外)の0が
の説明と例からだと
「先頭以外」が先頭の0、1文字を指すのか
先頭から続く0の塊を指すのか不明でしょ
> 3つ以上並ぶ部分
が強欲なのか?欲張りでいいのか?が不明 >>511 さんの質問だね
520: 2022/09/13(火)23:09 ID:G28B9gdh(3/4) AAS
>>519
訂正、>>510さんの質問
521: 2022/09/13(火)23:10 ID:aae9uQ50(3/4) AAS
みなさんありがとうございます!
できそうな正規表現がありうれしいです。
すみませんが今手元に環境がないため明日動作させて確認します。
522: 2022/09/13(火)23:20 ID:aae9uQ50(4/4) AAS
そして自分でも要件を言葉にできておらず申し訳ありません
みなさんに質問いただいて初めて気付きましたが、
先頭及び末尾が0であった場合、そこから連続する0は除外する ができると一番望ましいです。
00001200034000
↓
000012-34000
となります。
返信遅くなりすみません。
523(1): 2022/09/13(火)23:44 ID:G28B9gdh(4/4) AAS
(?<!^)(?>0{3,})(?!$)
未test
最初のマッチだけ置換は以下
外部リンク:social.technet.microsoft.com
524(1): 2022/09/14(水)00:51 ID:4SNfctPQ(1) AAS
>>518
あかんすね…
^(0*)((0{0,2}[1-9])+)0{3,}([1-9]\d*)$ --> $1$2-$4
これはどーでしょう?
525(1): 2022/09/14(水)05:23 ID:E5sTi1VY(1) AAS
([1-9])0000*([1-9][0-9]*)
$1-$2
526(1): 2022/09/14(水)09:12 ID:Kn3Wl+2J(1) AAS
(?<=[1-9])(?>000+)(?!$)(.+)$
-$1
527(1): 2022/09/14(水)09:38 ID:s0UMl1ds(1) AAS
(^[^0].*?)0{3,}([^0].*?$)
$1-$2
528: 2022/09/14(水)10:42 ID:6Qq1IObP(1) AAS
○ >>524,525,526
✕ >>523,527
529: 2022/09/14(水)19:22 ID:+0SwTq6N(1/2) AAS
508です。
沢山の案ありがとうございました、本当に助かりました。
一通り試して正しく動くものは沢山あったのですが、
以下の方式で解決させていただきました。
$reg=[regex]'([1-9])0000*([1-9][0-9]*)'
$reg.Replace($str,'$1-$2',1)
また、上記の案以外もこんな解決方法があるのかととても勉強になりました。
そして自分が要件をまとめられてなかったことにも反省いたしました。
今後はこちらで回答する側になれるよう、再度勉強いたします。
重ね重ね本当にありがとうございました。
530(1): 2022/09/14(水)19:57 ID:b2aEm1i9(1) AAS
回答にある正規表現は置換回数を指定できない置換方法でも大丈夫
置換回数に1を指定する方法でやるなら単に ([1-9])0000*([1-9]) でもいい
531: 2022/09/14(水)22:22 ID:+0SwTq6N(2/2) AAS
>530
確かに、教えていただいたこともりもりにしてしまいましたが
わざわざ[1-9]のあとに[0-9]を入れている意味がないですね…。
ご指摘ありがとうございます。
532(1): 2022/09/18(日)12:56 ID:QaJ1iFM2(1) AAS
githubで結構探したんですがそれっぽいのが見つからず、お力お貸しください。
●Regular Expressionの使用環境
AutoHotKey1.1系
●検索か置換か?
置換
●説明
2つのクォーテーションマークに囲まれたパスのうち、1つ目(app.exe)を削除したい。
囲まれたパス同士は半角スペースで接続される。
●対象データ
"D:\Dir_Path\_app.exe" "D:\Dir_Path\_script.ahk"
省3
533(1): 2022/09/18(日)16:16 ID:wjpqonb4(1) AAS
>>532
外部リンク:regex101.com
534: 2022/09/18(日)19:20 ID:/uA/jgNo(1) AAS
>>533
ありがとうございますめちゃくちゃシンプルでした!あとこのregexサービスいいですね
".*"\s だと構文エラー吐きました
置換関数内(””の中)で”がうまく扱えないので頑張ってみます。
535(1): 2022/09/18(日)21:26 ID:CbZe8FP4(1) AAS
"を
\"
や
\x22
に置き換えて試してみてわ
536: 2022/09/19(月)16:41 ID:4iw9Mtek(1) AAS
>>535
ありがとうございます、いけました
(ついでに””も削除)
\x22.*\x22\s|\x22
537: 2022/09/20(火)02:58 ID:94I1wBUa(1) AAS
二重引用符のエスケープは重ねて""だな
"".*""\s
538(1): 2022/10/29(土)13:09 ID:ec13kmtS(1/2) AAS
●Regular Expressionの使用環境
PCRE2
●検索か置換か?
検索
●説明
(..[\0@-g]\0){147}などを高速に検索したい
●対象データ
メガ単位のバイナリファイル(リトルエンディアン)
●希望する結果
説明は一例なので前中後にリテラルパターンが入る事もありますが(16KiBを越える事も)、固定長で
省11
539(1): 2022/10/29(土)19:31 ID:9Ey1MUJ8(1) AAS
>>538
\0@って何?
\c@でNULL文字検索の意味ではないの?
540: 2022/10/29(土)19:42 ID:ec13kmtS(2/2) AAS
>>539
文字クラス[\0@-g]なので表記を統一するなら[\x00\x40-\x67]になります
541(2): 2022/10/30(日)10:24 ID:dZd+t5oq(1) AAS
スプレッドシートで20221030と入力されている数字を日付の表記?2022/10/30なのか10/30/2022なのかわからないけどDATEDIF関数に使える形に置換する正規表現ってどう書きますでしょうか
542(1): 2022/10/30(日)11:55 ID:oF72FRjI(1) AAS
>>541
正規表現では無理。スレチ
DATE関数で日付にかDATEVALUE関数でシリアル値に変換
セルA1の値:20221030
=DATE(LEFT(A1,4),MID(A1,5,2),RIGHT(A1,2))
=DATEDIF(DATE(LEFT(A1,4),MID(A1,5,2),RIGHT(A1,2)),"2022/11/01","D")
543: 2022/10/30(日)12:28 ID:S1PTRz+V(1) AAS
>>541
=DATEVALUE(REGEXREPLACE(A1, "^(....)(..)(..)$", "$1/$2/$3"))
>>542
スレチ
544: 2022/11/02(水)14:16 ID:gx4Z74sz(1/3) AAS
すいません。
0と正の整数のみにマッチする正規表現はどう書きますか
----
OK
0
1
22
303
999999
----
省4
545: 2022/11/02(水)14:20 ID:4jxQNd6r(1) AAS
^\d+$
546: 2022/11/02(水)14:26 ID:gx4Z74sz(2/3) AAS
ありがとうございました!
547(1): 2022/11/02(水)14:39 ID:Hz9+pCnD(1) AAS
00
00000000
012
003102
とかはええんかC言語だと8進数なんだけど
上下前次1-新書関写板覧索設栞歴
あと 455 レスあります
スレ情報 赤レス抽出 画像レス抽出 歴の未読スレ AAサムネイル
ぬこの手 ぬこTOP 0.072s