• 締切済み

マクロと複数文字列一括置換の(私には)複雑な話

nishi6の回答

  • nishi6
  • ベストアンサー率67% (869/1280)
回答No.2

かなり日にちも経って無意味ですかね。ユーザー定義関数を作ってみましたので参考に投稿します。 多分、駅名を変換するデータがあると思って作っています。前提は、シートのどこかに変換テーブル、例えば、  新宿    1  京成幕張  2  新宿三丁目 3  日暮里   4  西日暮里  5  蒲田    6  京急蒲田  7  幕張    8 のようなものがあるとして、これに範囲名『data』を付けます。 使い方は、A1に駅名があれば、別のセルで =EkimeiOkikae(A1) とします。 セルには『:』で分けられた駅名が何個あってもかまいません。 以下を標準モジュールに貼り付けます。 Public Function EkimeiOkikae(Ekimei As String)   Dim wkEkimei As String 'セルの内容(ワーク)   Dim wkEkiElm As String 'セルの駅名の1つ   Dim pot As Integer '2つの駅名を分ける位置   Application.Volatile '自動再計算関数にする   wkEkimei = Ekimei & ":" '駅名が1つ、2つ以上を同じ形式にする   pot = InStr(wkEkimei, ":")   While pot > 0     wkEkiElm = Left(wkEkimei, pot - 1) '1つの駅名     wkEkiElm = Application.VLookup(wkEkiElm, Range("data"), 2, False) 'dataから検索     EkimeiOkikae = EkimeiOkikae & wkEkiElm & ":" '検索結果     wkEkimei = Right(wkEkimei, Len(wkEkimei) - pot) '複数の場合の次の駅名     pot = InStr(wkEkimei, ":")   Wend   EkimeiOkikae = Left(EkimeiOkikae, Len(EkimeiOkikae) - 1) '最後の『:』を除く End Function

G-integal
質問者

お礼

丁寧なご回答、 ありがとうございます。 また、お礼が遅くなってすいません。 ご回答頂いたのもお忘れかと思うほど時間が経ってしまいました。 >多分、駅名を変換するデータがあると思って作っています。 あります。 難しそうですが、チャレンジしてみます。 「転ばぬ先の杖」とはいいつつも自分の必要な知識から虫食いのように 勉強しています。 来年2月からは本格的に・・・。と密かに考えてはいるのですが・・・。 本当にありがとうございました。

関連するQ&A

  • エクセルで置換のマクロの際

    Selection.Replace What:="あ", Replacement:="", LookAt:=xlPart, _ SearchOrder:=xlByRows, MatchCase:=False エクセルのマクロで置換をする際に 自動記録で書くとこうなります。 「あ」を「(空白)」におきかえる内容ですが 置き換え候補がたくさんある場合は 上記の記述をくりかえし記述するしかないのでしょうか? 例 「あ」を「」に 「い」「」に   というような具合です

  • エクセル2003で特殊文字の置換方法

    エクセル2003、XPを使用しています。 エクセルのマクロで置換をしているのですが、 置換対象がCHAR(160)です。 セル上に上のを打ち込むと、実際は違いますが半角スペースに見えます。 特殊文字であっているのでしょうか。 それで、この文字を消したいと思い、以下の通りマクロで記述しているのですが、成功しません おわかりになる方いらしたらよろしくお願いします。 Cells.Replace What:=Chr(160), Replacement:="", LookAt:=xlPart, SearchOrder:= _ xlByRows, MatchCase:=False, SearchFormat:=False, ReplaceFormat:=False

  • Excelマクロ 置換について教えてください。

    A列の,10を,15に置換したいので下記マクロを記録しました。 ほかに,10を,16などにしたい場合もあるため、 入力画面を表示して初期値は,10から,15ですが、ほかを入力した場合は他の値で置換するマクロを教えてください。 Sub Macro1() Columns("A:A").Select Selection.Replace What:=",10", Replacement:=",15", LookAt:=xlPart, _ SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _ ReplaceFormat:=False End Sub

  • エクセルでマクロを使用しての置換

    マクロ初心者です。 データを変換するシステムをマクロで作成していますが、 自分のPCではちゃんと実行できるのに、お客さんのPCで実行するとエラーが出てしまいます。 エラーが出る部分は、どうも置換するところらしく、 Selection.Replace What:="<BR>", Replacement:="", LookAt:=xlPart, _ SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _ ReplaceFormat:=False ここが黄色く表示されるそうです。 どこを直せばよいですか?

  • 置換のマクロ

    先ほど質問させていただいている件なのですが 余りにも自分が記入した内容が分かりにくいので質問形式を変更します。 「置換」をするのに ボタンで簡単にできるよう以下のマクロを記録しました。 Sub Macro1() ActiveWindow.SmallScroll Down:=-15 Range("E7:AC7").Select Selection.Replace What:="2009年度契約", Replacement:="8.24-8.29", LookAt:=xlPart, _ SearchOrder:=xlByRows, MatchCase:=False Range("E14:AC14").Select Selection.Replace What:="2009年度契約", Replacement:="8.24-8.29", LookAt:=xlPart, _ このマクロの「8.24-8.29」の部分を「シート名取得」にしたいのです。出来ないでしょうか? もしくは BOXを出し任意のものを手で入力するようにコメントを出す様には出来ないでしょうか?

  • エクセルのマクロ 大量の置換の記述を簡略化

    Cells.Select Selection.Replace What:="東京", Replacement:="東京都", LookAt:=xlPart, _ SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _ ReplaceFormat:=False このような置換のマクロが何十個とあって 置換前の語句と置換後の語句ごとに すべて記述していますが 「置換の記述そのものはまったく同じなので  その中に語句を順番に入れ込んでいく」 という風な記述はできるものでしょうか? もし方法があるならば御教授願いたいです 宜しくお願い致します

  • エクセルで指定した文字に自動で置換することは可能ですか??

    A1セルに「バナナ」と表示されると下のマクロの記録で作った”置換するマクロ”の「りんご」の部分を「バナナ」に変更し、さらにこの置換マクロを自動実行することはできますか?? Sub Macro1()' Cells.Select Selection.Replace What:="名前(1)", Replacement:="りんご", LookAt:=xlPart, _ SearchOrder:=xlByRows, MatchCase:=False, SearchFormat:=False, _ ReplaceFormat:=False Range("A1").Select End Sub このマクロの記録でなくてもいいんですが、あるセルに置換したい文字が表示された時点でシート内の置換が実行されるようにしたいんですけど・・・・・。 よろしくお願いします。

  • マクロエラ-

    初心者です。win2000,エクセルでマクロが途中で止まってしまいます。時々に、最後までいくことがありますが、8割がたは、同じところでストップします。 マクロ言語は理解できていません。 うまく完了のケ-スは、デ-タの中身次第かなと思います。 記憶では、”0”があれば、何かをするようにしたと思います。 想定外のデ-タで、とまるのなら、回避方法を教えてください。 黄色反転して、ストップする部分は、以下です。 mcr3 Range("A1").Select ActiveCell.SpecialCells(xlLastCell).Select Columns("C:C").Select Selection.Find(What:="0", After:=ActiveCell, LookIn:=xlFormulas, LookAt _ :=xlWhole, SearchOrder:=xlByRows, SearchDirection:=xlNext, MatchCase:= _ False, MatchByte:=False).Activate いつもここで止まります。 ActiveCell.Replace What:="0", Replacement:="", LookAt:=xlWhole, _ SearchOrder:=xlByRows, MatchCase:=False, MatchByte:=False Selection.Find(What:="0", After:=ActiveCell, LookIn:=xlFormulas, LookAt _ :=xlWhole, SearchOrder:=xlByRows, SearchDirection:=xlNext, MatchCase:= _ False, MatchByte:=False).Activate -----------→つずく。

  • 二重引用符の置換処理に関して

    エクセルで特定のセルに二重引用符が入力されていた場合、“を““のように置換させたいです。 しかし、下記ソースではエラーが発生してプログラムが動きません。 Columns("J:O").Replace What:="“", Replacement:="““", LookAt:=xlPart, _ SearchOrder:=xlByRows, MatchCase:=False どうすれば正常に置換することが出来るでしょうか? 宜しくお願いします。

  • excel「マクロ」 置換えで困っています。

    いつも皆様には大変お世話になっております、回答者の皆様ありがとう御座います。 早速ですが質問させて頂きます。 初めてexcelにて 「置換え」 マクロを組んでいます、置き換えなければいけない候補が多いので Sub okikae() Dim myRng As Range Selection.SpecialCells(xlCellTypeConstants, 2).Select For Each myRng In Selection myRng.Value = StrConv(myRng.Value, vbUpperCase + vbNarrow) Next myRng Dim aa, zz As Integer, a, za As Integer aa = Array("-10", "P10", "P-10") a = Array("-1", "P1", "P01", "P-1", "G1", "G01", "G-1", "-") For zz = 0 To UBound(aa) Selection.Replace What:=aa(zz), Replacement:="@10", _ LookAt:=xlPart, SearchOrder:=xlByRows, MatchCase:=False Next zz For za = 0 To UBound(a) Selection.Replace What:=a(za), Replacement:="", _ LookAt:=xlPart, SearchOrder:=xlByRows, MatchCase:=False Next za end sub 上記の様なマクロを永遠と入力しました。(実際にはもっと長いです。(入力を多数の人数で行っている為、同じP1やP10がイロイロな形式で入力されています。) セルを選択しマクロを実行したところ、うまく置換えが出来たり出来なかったりするセルが出てきて困っています。 どこに不具合があり、置換え出来なくなっているのかすら分からない状態に陥っています。 アドバイスありましたら宜しくお願いいたします、説明に不明な点があれば再度補足させて頂きます。