VBAで指定列からAを検索し、発見したら隣のセルに0を入れるマクロを組みたいのですが、組み方がVBA初心者の為わかりません。
(例)
L列に、A、B、C、D、E、Fとランダムに文字が入っていて、
文字Aを検索し、発見したら隣のI列に値0を入れるというマクロです。
Sub Search()
Dim A As String
Set A = Worksheets("Sheet1").Cells.Find("A")
If A Is Nothing Then
ActiveCell.Offset(0, 1).Value = 0
End If
End Sub
と過去の質問で考えてみたのですが、Aがあった時、、、、
とコードが書けないです。
大変困っているので、ご教授頂けないでしょうか?
出来れば、そのままマクロに出来るコードを教えて頂けないでしょうか?
宜しくお願い致します。
No.4ベストアンサー
- 回答日時:
こんばんは。
#3さんのおっしゃっていることも、もっともなのですが、気になる点がありましたので、自分のことを踏まえて、書かせていただきます。
いずれ、また、同じようなケースが出会うと思います。こんな原則を考えてみたらどうでしょうか?それは、私も自身も同じなのですが、ワークシートのコマンドで行われるものは、記録マクロから作ってみるということです。他にも、「統合」とか、「置換」とか「オートフィルタ」「フィルタオプション」とかは、みんなパターンが決まっています。
その中の代表格が、この「Find」 です。
>Set A = Worksheets("Sheet1").Cells.Find("A")
>過去の質問で考えてみたのです
どうも、Find メソッドは、あるレベル以下の人は、省略する傾向があるようです。何が大事で、何が大事でないかというのは、やってみなければ分かりませんが、検索語だけを入れる書き方は、実務では、あまりしないほうがよいと思います。
だいたい、以下のTestFind2 ぐらいまでに、省略は、とどめたほうがよいです。
それは、Find は、必ずしも自分が思っているデフォルトとは違うことがあるので、「明示的(意図的に)」にオプションは入れたほうがよいです。
例えば、大文字小文字の違いを付けるなら、MatchCase:=True, 数式まで探すなら、LookIn:=xlFormulas
なお、Find メソッドは、5年経っても、たぶん完全に覚えられません。面倒なコードのひとつです。ですが、これはパターンが決まっているので、ひとつパターンが決まったら、それに当てはめればよいだけです。
#3さんで示されているMougのサンプルコードと似てはいるのですが、Mougのサンプルコードでは、Verionによって、失敗することがあります。
'--------------------------------------
'記録マクロをそのまま使う方法
Sub TestFind1()
Dim c As Range
Set c = Columns("L:L").Find(What:="A", _
After:=ActiveCell, _
LookIn:=xlValues, _
LookAt:=xlPart, _
SearchOrder:=xlByRows, _
SearchDirection:=xlNext, _
MatchCase:=False, _
MatchByte:=False, _
SearchFormat:=False)
c.Offset(0, 1).Value = 0
End Sub
'--------------------------------------
'TestFind1 をアレンジしてみる
Sub TestFind2()
Dim c As Range
'検索語
Const MYTXT As String = "A"
Set c = ActiveSheet.Columns("L:L").Find(What:=MYTXT, _
LookIn:=xlValues, _
LookAt:=xlPart, _
MatchCase:=False)
If Not c Is Nothing Then
c.Offset(0, 1).Value = 0
End If
End Sub
'---------------------------------------
'複数ある場合(パターンを使った方法)
'---------------------------------------
Sub TestFind3()
Dim c As Range
Dim FirstAdd As String
Const MYTXT As String = "A"
Set c = ActiveSheet.Columns("L:L").Find( _
What:=MYTXT, _
LookIn:=xlValues, _
LookAt:=xlPart, _
MatchCase:=False)
If Not c Is Nothing Then
FirstAdd = c.Address
Do
c.Offset(, 1).Value = 0
Set c = ActiveSheet.Columns("L:L").FindNext(c)
If c.Address = FirstAdd Then Exit Sub
Loop Until c Is Nothing
End If
End Sub
No.5
- 回答日時:
再度の登場、onlyromです。
>For R = 1 To Cells(Rows.Count, "L").End(xlUp).Row
>の部分はどのような処理をしているのでしょうか?
Cells(Rows.Count, "L").End(xlUp).Rowのことですね?
これで、L列の最終行(データのある最終行)を求めています。
例えば、L列データが1行目~555行目まで入力されていたら
For R = 1 To 555
でもいいのですが、いつも555行目までデータが入力されているとは限らないはずですから、
For R = 1 to 555 と最終行を決めうちすると最終行が変更になる度に
For R = 1 to 100 とか
For R = 1 to 200 などと最終行を変更しなければいけません。
で最終行に変更があってもコードを変更しなくていいように
Cells(Rows.Count, "L").End(xlUp).Row
これで自動的にL列の最終行を求めているわけです。
最終行を求めるときはこうするんだと丸暗記してください。
それから先の回答でも言いましたがFindメソッドはとても便利なメソッドですから
暇なときにでもヘルプなど眺めしっかり学習しませう。
No.3
- 回答日時:
マクロの記録モードにして、編集ー検索の操作をして、Aを検索し見つかってもさらに数度、次を検索、を続けてマクロの記録を編集で見てください。
全てはそれからです。、>そのままマクロに出来るコードを教えて頂けないでしょうか
丸投げといい、回答者を下請けと看做す態度で、規約上しないことになってます。
問題は検索を終わりにする判定です。検索操作ではまた最初に戻って検索を続けるので、最初に戻ったこと、そこを条件にします。
この検索はFind,FindNextの2つを使う必要があり、終わり条件を組み込むのが難しく初心者が手を出す課題ではない。
ただ「VBA Find FindNext」でWEB照会すれば沢山実例が出てくる・それらを読みもしないで・・。
http://www.moug.net/tech/exvba/0050116.htm
など多数
No.2
- 回答日時:
質問者にはまだFindメソッドは難しいでしょうから、
次のようにオーソドックスな方法がいいでしょう。
L列に「A」があった場合、隣(M列)に「0」をセットする場合
'----------------------------------------------------
Sub Test()
Dim R As Long
Range("M:M").ClearContents
For R = 1 To Cells(Rows.Count, "L").End(xlUp).Row
If Cells(R, "L").Value = "A" Then
Cells(R, "M").Value = 0
End If
Next R
End Sub
'---------------------------------------------------------
それから、「A」という文字を含む
例えば、「A00」とか「xxA」とかの場合も該当にする場合は
If Cells(R, "L").Value Like "*A*" Then
とLikeを使います。
またFindメソッドはゆっくりじっくり勉強してください。
onlyrom様
ご回答ありがとうございます。
今、試してみたら出来ました!
本当にありがとうございます!!
M列には他の値も入っていたので、Range("M:M").ClearContents
は消させて頂きました。
ちなみに、
For R = 1 To Cells(Rows.Count, "L").End(xlUp).Row
の部分はどのような処理をしているのでしょうか?
No.1
- 回答日時:
>Dim A As String
変数Aは文字列型
>Set A = Worksheets("Sheet1").Cells.Find("A")
検索範囲はシート1の全てのセル、且つ変数Aにセットされるのは
Rang型
>If A Is Nothing Then
変数Aが”Nothing:見つからなかった場合に”と言う事。
この回答への補足
n-jun様、アドバイスありがとうございます。
初心者の為、こんな質問をして申し訳ないのですが。
「Aが見つかったら」と書くにはどのようにすれば宜しいでしょうか?
尚、変数宣言をするときに、String型ではなくRang型で宣言すれば宜しいのでしょうか?
ご教授お願い致します!
>Dim A As String
変数Aは文字列型
>Set A = Worksheets("Sheet1").Cells.Find("A")
検索範囲はシート1の全てのセル、且つ変数Aにセットされるのは
Rang型
>If A Is Nothing Then
変数Aが”Nothing:見つからなかった場合に”と言う事。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) エクセルVBAのコードで質問です。 下のコードはJ16の文字列をB3を起点とする範囲から探して、見つ 5 2023/04/07 11:07
- Visual Basic(VBA) excel VBA if文について 3 2022/03/27 17:42
- Visual Basic(VBA) シフト表のコマで「ブロック」されている前の時間の「出」を同一列の「休」と入れ替えたいがふぇきません。 2 2023/08/02 18:49
- Visual Basic(VBA) excel2021で実行できないマクロ。どこを直したらいいのか 2 2022/03/28 03:40
- Visual Basic(VBA) まとめシートから集計シートへA列のコードが一致したら1行コピーするマクロをネット上で見つけました。こ 1 2022/08/30 14:11
- Excel(エクセル) エクセルのイベントプロシージャーでF列の最終行のセルの入力をトリガーにしたいのですが 1 2022/10/14 09:36
- Excel(エクセル) 指定文字列が該当するA列をアクティブセルにするには 3 2022/08/17 13:18
- Visual Basic(VBA) 複数csvを横に追加していくマクロについて 2 2023/04/25 09:19
- Visual Basic(VBA) オブジェクトが見つかりません 1 2023/06/24 19:43
- Excel(エクセル) エクセルVBA、ファイル名をセルの値で保存の方法を教えてください。 おそれいります。こちらで数々のエ 6 2023/06/30 22:17
このQ&Aを見た人はこんなQ&Aも見ています
-
これまでで一番「情けなかったとき」はいつですか?
これまでの人生で一番「情けない」と感じていたときはいつですか? そこからどう変化していきましたか?
-
歳とったな〜〜と思ったことは?
歳とったな〜〜〜、老いたな〜〜と思った具体的な瞬間はありますか?
-
モテ期を経験した方いらっしゃいますか?
一生に一度はモテ期があるといいますが、みなさんどうですか? いまがそう! という方も、「思い返せばこの頃だったなぁ」という方も、よかったら教えて下さい。
-
この人頭いいなと思ったエピソード
一緒にいたときに「この人頭いいな」と思ったエピソードを教えてください
-
「これいらなくない?」という慣習、教えてください
現代になって省略されてきたとはいえ、必要性のない慣習や風習、ありませんか?
-
ある範囲のセルから任意の値を検索して、その隣のセルの値を取得するという関数はありますか?
Excel(エクセル)
-
エクセルVBAで、条件に一致するセルへ移動
Excel(エクセル)
-
Excelで、検索してヒットしたセルの隣のセルに値を入力したい
Excel(エクセル)
-
-
4
VBAで条件に一致するセルの隣の値をまとめる方法
Excel(エクセル)
-
5
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
6
vba 2つの条件が一致したらコピーして別シートに値のみ貼り付け
Visual Basic(VBA)
-
7
【EXCEL】【VBA】空欄は飛ばして処理する方法を教えて下さい。
Excel(エクセル)
-
8
【VBA】2つのシートの値を比較して条件一致したら、同じ行の隣の値を別ブックへ転記したいです。 VB
Visual Basic(VBA)
-
9
VBAで特定の文字を探して隣のセルに色を付けたい
Excel(エクセル)
-
10
VBAで文字列を数値に変換したい
Excel(エクセル)
-
11
数式による空白を無視して最終行を取得するマクロ
Excel(エクセル)
-
12
エクセルで条件に一致したセルの隣のセルを取得したい
その他(Microsoft Office)
-
13
UserForm1.Showでエラーになります。
工学
-
14
Excel マクロ VBA 別シートのセルを検索し、該当するセルの右にあるセルを入力させる方法 s
Visual Basic(VBA)
-
15
エクセルで指定した行で条件に一致したセルの右隣のセルを取得したい
Excel(エクセル)
-
16
指定した文字があった場合、その行を削除するマクロが欲しいです
Excel(エクセル)
-
17
エクセル 同じ値を探して隣の数値をコピーする
Excel(エクセル)
-
18
EXCELのVBA-フィルタ抽出後のセル選択方法
Visual Basic(VBA)
-
19
完全一致したら代入するマクロを教えてください
Excel(エクセル)
-
20
excel VBAで、置換した結果を別のセルに出力
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・「みんな教えて! 選手権!!」開催のお知らせ
- ・漫画をレンタルでお得に読める!
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・【選手権お題その3】この画像で一言【大喜利】
- ・【お題】逆襲の桃太郎
- ・自分独自の健康法はある?
- ・最強の防寒、あったか術を教えてください!
- ・【大喜利】【投稿~1/9】 忍者がやってるYouTubeが炎上してしまった理由
- ・歳とったな〜〜と思ったことは?
- ・ちょっと先の未来クイズ第6問
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・【選手権お題その2】この漫画の2コマ目を考えてください
- ・【選手権お題その1】これってもしかして自分だけかもしれないな…と思うあるあるを教えてください
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで特定の列が0表示の場...
-
Excel マクロ VBA プロシー...
-
メッセージボックスのOKボタ...
-
Excel・Word リサーチ機能を無...
-
エクセルで別のセルにあるふり...
-
ExcelのVBA。public変数の値が...
-
マクロで空白セルを詰めて別シ...
-
VBAパスワードを解除するマクロ
-
特定のPCだけ動作しないVBAマク...
-
エクセルに張り付けた写真のフ...
-
非表示の列をすべて削除するマクロ
-
Excel VBAからAccessマクロを実...
-
エクセル マクロでマクロ名が変...
-
一つのTeratermのマクロで複数...
-
vba マクロでファイル名をつけ...
-
Excel マクロでShearePoint先の...
-
#defineの定数を文字列として読...
-
OnTime NOW + TIMEVALUE("00:00...
-
ExcelVBAでPDFを閉じるソース
-
Pythonでexcelのvbaを作成、実...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
特定のPCだけ動作しないVBAマク...
-
Excel・Word リサーチ機能を無...
-
一つのTeratermのマクロで複数...
-
エクセルで特定の列が0表示の場...
-
Excel マクロ VBA プロシー...
-
メッセージボックスのOKボタ...
-
Excel マクロでShearePoint先の...
-
エクセルに張り付けた写真のフ...
-
Excel_マクロ_現在開いているシ...
-
ExcelのVBA。public変数の値が...
-
TERA TERMを隠す方法
-
ExcelVBAでPDFを閉じるソース
-
Excel VBAからAccessマクロを実...
-
エクセルで縦に並んだデータを...
-
マクロ実行時、ユーザーフォー...
-
エクセルで別のセルにあるふり...
-
wordを起動した際に特定のペー...
-
特定文字のある行の前に空白行...
-
【EXCEL VBA】オートシェイプを...
-
ソース内の行末に\\
おすすめ情報