質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

解決済

2回答

665閲覧

vbaの正規表現で前方・後方任意0文字以上での不一致

maguzo

総合スコア57

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2018/10/22 00:09

以下の正規表現.●●●.でTrueを返すことを期待しているのですが
falseとなってしまいます。Replaceを置いているのは、B列の値は末尾に
半角スペースが含まれるからです。
週末悩んでも解決しなかったため、ご相談させて頂きたく投稿いたしました。

アドバイスを頂けたら、幸いです。

AB
あおば銀行株式会社あおば銀行

vba

1前略 2Set reg = CreateObject("VBScript.RegExp") 3  reg.Pattern = "." & Replace(sheetpiyo.Cells(B1).Value, " ", "") & "." 4 5 If reg.Test(sheetpiyo.Cells(A1).Value) = True Then 6 pts.Cells(C1) = "曖昧一致します" 7  End If 8後略

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

このケース(指定した文字列が、対象文字列の一部である)では、正規表現を使わず、Instr関数を使うのが良いです。

投稿2018/10/22 03:39

otn

総合スコア84538

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ExcelVBAer

2018/10/23 00:20

自分もInstrが適当だと思います。 難しい正規表現が好きな方が多いようですねぇ。。。
TanakaHiroaki

2018/10/23 12:38

私もInstrとReplaceが、見落としが起きにくいので良いと思います。
guest

0

ベストアンサー

「.」は一文字を表します。
「.あおば銀行」は、「ああおば銀行」「ばあおば銀行」などにマッチします。
「あおば銀行.*」ではないですか?

週末潰して悩むならその時間を正規表現について調べることに費やす方が早く解決します。

投稿2018/10/22 00:22

Zuishin

総合スコア28660

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

maguzo

2018/10/22 01:25

ご教示有難うございます。"."で0個以上の任意の文字と誤解しておりました。 仰るとおり、正規表現そのものをよく調べるべきでした。 また、株式会社あおば銀行の可能性もあるため、.*あおば銀行.* という正規表現で実行いたしました。 宜しくお願い申し上げます。
Zuishin

2018/10/22 01:33

このような単純な検索の場合は「あおば銀行」で「株式会社あおば銀行本店」にマッチします。 また店名にメタ文字が含まれている場合があるので、正規表現の中にそうでない文字列を含める場合はエスケープするのが鉄則です。 エスケープしないと、例えば「*** Flowers ***」という会社名が仮にあった時に困ります。 これをエスケープして「*** Flowers ***」に変換しなければいけません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問