いつもお世話になっています。
質問タイトルのとおりなのですが、以下ページを参照して置換を試したところ、
セル内に置換したい文字列が複数回出てくる場合にうまくいきません。
https://oshiete.goo.ne.jp/qa/2428455.html
具体的には、セル内の最初の文字列は正常に置換され、書式も指定のものに変更されるのですが、
同じセル内に二回目以降に出現する文字列は置換も書式変更もされません。
例)
「私は犬が好きです。犬は私の友達です。」
の文章の「犬」を「猫」に置換しようとした場合、
「私は猫が好きです。犬は私の友達です。」
と、二回目の犬が置換されません。
この場合は、どのようにVBAを修正したらよろしいでしょうか。
No.6ベストアンサー
- 回答日時:
#5です 置き換えもやるのでしたね
Sub ReplaceFormatInCells()も変更して
Sub ReplaceFormatInCells()
Dim sWhat As String, mWhat As String
Dim mFadd As String
Dim c As Range
sWhat = Application.InputBox("検索する単語を入れてください。", Type:=2)
If sWhat = "False" Or sWhat = "" Then Exit Sub
mWhat = Application.InputBox("置き換え後の単語を入れてください。", Type:=2)
If mWhat = "False" Or mWhat = "" Then Exit Sub
Cells.Replace what:=sWhat, replacement:=mWhat, lookat:=xlPart
Set c = ActiveSheet.UsedRange.Find( _
what:=mWhat, _
LookIn:=xlValues, _
lookat:=xlPart, _
SearchDirection:=xlNext, _
MatchCase:=True, _
MatchByte:=True)
If Not c Is Nothing Then
mFadd = c.Address
ReplaceFont c, mWhat
Do
Set c = ActiveSheet.UsedRange.FindNext(c)
If c.Address = mFadd Then Exit Sub
ReplaceFont c, mWhat
Loop Until c Is Nothing
End If
End Sub
Private Const の設定は不要です。
再度のご回答ありがとうござました。
おかげさまで目的の操作が実現できました!
今回お二方から再回答をいただき、どちらも目的の操作が実現できましたが、
こちらのご回答内容の方が他の操作にも転用できて使い勝手が良さそうでしたのでベストアンサーとさせていただきます。
No.5
- 回答日時:
リンク先のコードをお借りして(質問者が検証を行っていると思いますので)
先のPrivate Sub ReplaceFont(rng As Range, strSearch As String)を書き換えてみました。
Sub ReplaceFormatInCells()部分は、其のままで良いかと思います。
Private Sub ReplaceFont(rng As Range, strSearch As String)
Dim i As Integer
Dim Ln As Integer
Ln = Len(strSearch)
i = InStr(1, rng.Value, strSearch)
Do While i > 0
With rng.Characters(i, Ln)
.Font.ColorIndex = 3
.Font.Strikethrough = True
End With
i = InStr(i + Ln, rng.Value, strSearch)
Loop
End Sub
No.4
- 回答日時:
No.3です。
>置換後の文字列を、文字色を赤、取り消し線を有りに書式を変更したいです。(セル内の全ての文字列を対象にしたくない)
単にデータだけでなく、書式も変えたい!というコトだったのですね。
どうも失礼しました。
セル全体の書式は簡単に変更できると思いますが、
セル内のある文字だけの書式変更は舐めるように順に検索していくしかないのでは?
↓のコードにしてみてください。
(尚、置換範囲はA1~H20セルとしています。)
Sub Sample2()
Dim k As Long
Dim c As Range, myRng As Range
Dim myStr1 As String, myStr2 As String
myStr1 = "犬" '//←検索文字列//
myStr2 = "猫" '//←置換後の文字列//
Set myRng = Range("A1:H20") '//ココで範囲指定//
'//▼まず一気に置換//
myRng.Replace what:=myStr1, replacement:=myStr2, lookat:=xlPart
'//▼各セルの操作//
For Each c In myRng
For k = 1 To Len(c)
If Mid(c, k, Len(myStr2)) = myStr2 Then
With c.Characters(Start:=k, Length:=Len(myStr2)).Font
.Strikethrough = True
.ColorIndex = 3
End With
End If
Next k
Next c
End Sub
こんなんではどうでしょうか?
※ 簡単にできる方法があればごめんなさい。m(_ _)m
No.3
- 回答日時:
こんにちは!
一例です。
具体的な配置が判らないので、すべてのセルを対象としてみました。
Sub Sample1()
ActiveSheet.Cells.Replace what:="犬", replacement:="猫", lookat:=xlPart
End Sub
こんな感じではどうでしょうか?m(_ _)m
No.1
- 回答日時:
例に合わせて回答すると
= Replace("私は犬が好きです。犬は私の友達です。", "犬", "猫")
参考: http://officetanaka.net/excel/vba/function/repla …
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) Excel VBA 教えてください。 VBA初心者です。 詳しい方がいましたら教えてください。 下記 3 2023/04/25 11:22
- Visual Basic(VBA) EXCEL VBA 単語置き換え について質問です ブック名 ぶぶぶ シート名 ししし セル V3〜 3 2023/03/08 01:41
- Visual Basic(VBA) Excel VBAでAA(BBB) → BBB.AA に置換したい 2 2022/10/30 13:59
- Excel(エクセル) 数式の置換がうまく行かない 6 2022/05/04 15:51
- Excel(エクセル) エクセルの日付から年末尾2桁と月を1月をA~Lに変換したい 3 2022/08/08 10:32
- Excel(エクセル) エクセルの数式について教えてください。 7 2023/06/18 10:16
- Visual Basic(VBA) 特定の文字を簡単な操作で半角スペースに変換するか削除したい 2 2022/11/01 10:35
- その他(コンピューター・テクノロジー) 正規表現の置換で一部の文字列をそのまま残したい 2 2022/05/03 19:19
- Visual Basic(VBA) EXCEL VBAで教えてください。 1 2022/12/22 04:20
- Excel(エクセル) エクセルの数式で教えてください。 2 2023/02/10 11:41
このQ&Aを見た人はこんなQ&Aも見ています
-
【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
【お題】 ・存在しそうで存在しないモノマネ芸人の名前を教えてください
-
チョコミントアイス
得意ですか?不得意ですか?できれば理由も教えてください。
-
「覚え間違い」を教えてください!
私はかなり長いこと「大団円」ということばを、たくさんの団員が祝ってくれるイメージで「大円団」だと間違えて覚えていました。
-
【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
【お題】 ・買ったばかりの自転車を分解してひと言
-
あなたの習慣について教えてください!!
あなたが習慣だと思って実践しているものを共有してくださいませんか? 筋肉トレーニングでも朝シャワーでも、あなたが習慣だなと思えば何でも構いません
-
エクセルでセル内の一部分だけ書式ごと置換したい
Excel(エクセル)
-
セル内の一部の色と文字列の置換
Word(ワード)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで文字の入力がセルの...
-
多数の計算セルに一括で同一の...
-
Excelからテキストへのコ...
-
エクセルのセルの中の,よりも前...
-
excelで可視セルのみ置換
-
Excelで、半角スペースをTABに...
-
Excelの空文字セルの削除方法を...
-
Excelのmatch関数エラー原因が...
-
Excelのシートにある1行...
-
置換機能を使わずに先頭に「'」...
-
エクセルの関数で、記号などを...
-
Excelの入力済みセルに一括で、...
-
エクセルの表ををメモ帳などに...
-
【エクセル】ピボットテーブル...
-
Excel折線グラフ作成でマイナス...
-
Excelのアポストロフィーの削除
-
エクセルで「4」「9」抜けの...
-
別シートのリストから置換する方法
-
セル内に○○円と入っている場合...
-
一括でダブルクリックした状態...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルで文字の入力がセルの...
-
多数の計算セルに一括で同一の...
-
エクセルのセルの中の,よりも前...
-
Excelからテキストへのコ...
-
Excelの空文字セルの削除方法を...
-
Excelで、半角スペースをTABに...
-
置換機能を使わずに先頭に「'」...
-
excelで可視セルのみ置換
-
エクセルでセル内の一部分だけ...
-
Excelのmatch関数エラー原因が...
-
Excelのシートにある1行...
-
小数点を消す方法
-
Excelの入力済みセルに一括で、...
-
【エクセル】ピボットテーブル...
-
エクセルの表ををメモ帳などに...
-
エクセルの関数で、記号などを...
-
Excelで特定の文字の前だけに空...
-
エクセルでスペースの記号を表...
-
企業名簿で(株)や(有)を無視し...
-
Excelのアポストロフィーの削除
おすすめ情報
ご回答ありがとうございます。
リンク先を確認させていただきましたが、記載されている例ではセルの値が置換したい文字列と完全一致しないといけないようです。
質問内容を補足をさせていただきます。
今回置換したい文字列は、シート内の50ヶ所以上のセルに存在します。
セル内には、置換したい文字列以外の文字列も含まれます。
セル内には、置換したい文字列が複数回出現する場合もあります。
置換後の文字列を、文字色を赤、取り消し線を有りに書式を変更したいです。(セル内の全ての文字列を対象にしたくない)
https://oshiete.goo.ne.jp/qa/2428455.html
のNo.4、No.5の回答を組み合わせる形で実行しましたが、
同一セルに二回以上置換したい文字列が出現する場合、
一番最初に出現するの置換希望文字列しか置換されません。
よろしくお願い致します。
ご回答ありがとうございます。
リンク先を確認させていただきましたが、記載されている例ではセルの値が置換したい文字列と完全一致しないといけないようです。
質問内容を補足をさせていただきます。
今回置換したい文字列は、シート内の50ヶ所以上のセルに存在します。
セル内には、置換したい文字列以外の文字列も含まれます。
セル内には、置換したい文字列が複数回出現する場合もあります。
置換後の文字列を、文字色を赤、取り消し線を有りに書式を変更したいです。(セル内の全ての文字列を対象にしたくない)
https://oshiete.goo.ne.jp/qa/2428455.html
のNo.4、No.5の回答を組み合わせる形で実行しましたが、
同一セルに二回以上置換したい文字列が出現する場合、
一番最初に出現するの置換希望文字列しか置換されません。
よろしくお願い致します。
ご回答ありがとうございます。
記載いただいた形で置換されることは確認できましたが、置換後の文字列のみ
書式変更する場合にはどのようにしたらよろしいでしょうか。
質問内容を補足をさせていただきます。
今回置換したい文字列は、シート内の50ヶ所以上のセルに存在します。
セル内には、置換したい文字列以外の文字列も含まれます。
セル内には、置換したい文字列が複数回出現する場合もあります。
置換後の文字列を、文字色を赤、取り消し線を有りに書式を変更したいです。(セル内の全ての文字列を対象にしたくない)
https://oshiete.goo.ne.jp/qa/2428455.html
のNo.4、No.5の回答を組み合わせる形で実行しましたが、
同一セルに二回以上置換したい文字列が出現する場合、
一番最初に出現するの置換希望文字列しか置換されません。
よろしくお願い致します。