
こんにちは。
業務でエクセルを使っていたのですが、
あまりに毎回時間がかかってしまうため、
VBAを利用して自動化したいと考えています。
まず、以下のようなシートが存在します。
A B C D E F G H
1
2 なす とまと 3 20
3 かぼちゃ えんどう 4 55
4 きゅうり りんご 2 82
5 とまと
6
7 みかん 3 10
8 にんじん ごぼう 9 21
9 はくさい うり 10 33
10 ねぎ
次のような作業を自動化したいのです。
1.A列に入っている野菜の名前と一致するものがF列にあるかどうか検索する。
2.もし一致するセルがあれば、そのセルとその横のセル、もう一つ横のセルをまとめてコピーしてそれぞれC、D、E列で、検索したもとの野菜と同じ行にペーストする。
3.この操作をA列にある全ての野菜について行い、
もし、F列に一致するものがなければ、CDE列は空欄にしておく。
4.A列一番下まで完了すれば作業終了。
以上です。
よろしくお願い致します。
A 回答 (4件)
- 最新から表示
- 回答順に表示
No.4
- 回答日時:
VLOOKUP関数を利用していますか。
利用しているなら、「あまりに毎回時間がかかってしまうため」とはどんなことですか。あるいは不便がありますか。
もし使ってないなら、それでは、「「業務」でエクセルを使っている」とはいえないぐらいの、重要な関数です。使ってください。
またVBAでWorksheetFunctionでVLOOKUPを使うことができます。
For Nextで全件比較を繰り回すのは、好きじゃない。
Findというメソッドもありますが。
No.3
- 回答日時:
No2です。
先ほどのでも大丈夫とは思いますが、念のため一箇所だけ修正しました。(点が一個抜けていました)
Sub 照合貼付()
Dim gA As Integer 'A列最大行
Dim gF As Integer 'F列最大行
Dim i As Integer 'ループ用
Dim n As Integer 'ループ用
With ActiveSheet
gA = .Range("A65536").End(xlUp).Row
gF = .Range("F65536").End(xlUp).Row
For i = 1 To gF
For n = 1 To gA
If .Cells(n, "A") <> "" Then '空白でない場合
If .Cells(n, "A") = .Cells(i, "F") Then '同一データがあったら
.Cells(n, "A").Offset(0, 1).Resize(1, 3).Value = .Cells(i, "F").Resize(1, 3).Value '転記
End If
End If
Next
Next
End With
End Sub
No.2
- 回答日時:
> 2.もし一致するセルがあれば、そのセルとその横のセル、もう一つ横のセルをまとめてコピー
FGH列をC、D、E列にですね?野菜名が重複するようですが・・・。
一応これで動くと思います。
Sub 照合貼付()
Dim gA As Integer 'A列最大行
Dim gF As Integer 'F列最大行
Dim i As Integer 'ループ用
Dim n As Integer 'ループ用
With ActiveSheet
gA = .Range("A65536").End(xlUp).Row
gF = .Range("F65536").End(xlUp).Row
For i = 1 To gF
For n = 1 To gA
If .Cells(n, "A") <> "" Then '空白でない場合
If .Cells(n, "A") = Cells(i, "F") Then '同一データがあったら
.Cells(n, "A").Offset(0, 1).Resize(1, 3).Value = .Cells(i, "F").Resize(1, 3).Value '転記
End If
End If
Next
Next
End With
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) 【Excel】指定のセル内容を基に別シートのセルを検索して選択する【VBA】 1 2022/06/16 16:16
- Excel(エクセル) VBA 特定の列に入っているテキストをコピペ 2 2023/06/14 11:24
- Visual Basic(VBA) VBA 検索と入力 Excel ブック ぶぶぶ シート ししし 列V 検索対象の列です 最終行は、お 6 2023/05/17 01:40
- Visual Basic(VBA) エクセルのマクロで対象ごとにシート分けしてその内容をセルに書き込みたい 9 2022/08/24 13:23
- Excel(エクセル) 関数EXACT(文字列,文字列)とexcelVBA 3 2022/04/14 15:07
- Visual Basic(VBA) vbaエクセルマクロ RemoveDuplicatesについて RemoveDuplicatesを使 3 2023/02/28 01:13
- Visual Basic(VBA) vbaエクセルマクロ RemoveDuplicatesについて RemoveDuplicatesを使 1 2023/02/27 22:21
- Excel(エクセル) シートが違う2枚のエクセルシートにある数値を別シートにコピーしたい(VBA?) 8 2022/03/31 12:24
- Excel(エクセル) エクセルのマクロでコピー後の貼り付け先を毎回指定したところにしたい 5 2022/08/12 10:47
- Visual Basic(VBA) Excel VBA 最終行を取得しVlookup関数をコピーする方法をコーディングで教えてください。 3 2023/05/11 13:14
このQ&Aを見た人はこんなQ&Aも見ています
-
「それ、メッセージ花火でわざわざ伝えること?」
「それ、メッセージ花火でわざわざ伝えること?」というメッセージを教えて下さい
-
初めて自分の家と他人の家が違う、と意識した時
子供の頃、友達の家に行くと「なんか自分の家と匂いが違うな?」って思いませんでしたか?
-
最速怪談選手権
できるだけ短い文章で怖がらせてください。
-
スタッフと宿泊客が全員斜め上を行くホテルのレビュー
スタッフも宿泊客も、一流を通り越して全員斜め上なホテルのレビューにありがちな内容を教えて下さい
-
あなたが好きな本屋さんを教えてください
どのくらいの規模間で、どのような本が並んでいるか、どのような雰囲気なのかなどなど...
-
vba 2つの条件が一致したらコピーして別シートに値のみ貼り付け
Visual Basic(VBA)
-
EXCEL VBA セルに既に入力されている文字に文字を追加する
Excel(エクセル)
-
【VBA】特定の値が入った行をコピーして別シートに貼り付ける方法をおしえていただきたいです。
Excel(エクセル)
-
-
4
エクセルVBAで、条件に一致するセルへ移動
Excel(エクセル)
-
5
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
6
EXCEL VBAで文字列の検索とコピー
Excel(エクセル)
-
7
VBAで検索して、行をコピー&追加したい
Excel(エクセル)
-
8
【VBA】特定列に文字が入っていたらそのセル行をコピーしてマスターブックの同じ行に貼り付けたい
その他(Microsoft Office)
-
9
エクセルVBAでセルに入力したパスでブックを開く
Excel(エクセル)
-
10
数式による空白を無視して最終行を取得するマクロ
Excel(エクセル)
-
11
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
12
EXCEL VBAで、セルの文字列の前後に文字を入力する方法は?
その他(Microsoft Office)
-
13
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
14
【EXCEL】【VBA】空欄は飛ばして処理する方法を教えて下さい。
Excel(エクセル)
-
15
VBA Cのセルが空白でなかったら、Aのセルに順番に数値を入力
Visual Basic(VBA)
-
16
worksheetFunctionクラスのVlookupプロパティを取得できません エラーへの対応
Visual Basic(VBA)
-
17
VBA 別ブックから条件に合うものを転記したいです
Visual Basic(VBA)
-
18
セルの値と同じ名前のシートをアクティブにするには?
Excel(エクセル)
-
19
VBAで文字列を数値に変換したい
Excel(エクセル)
-
20
エクセルのマクロで検索・抽出したデータを修正及び更新して元データに反映
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・「それ、メッセージ花火でわざわざ伝えること?」
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・【お題】甲子園での思い出の残し方
- ・【お題】動物のキャッチフレーズ
- ・人生で一番思い出に残ってる靴
- ・これ何て呼びますか Part2
- ・スタッフと宿泊客が全員斜め上を行くホテルのレビュー
- ・あなたが好きな本屋さんを教えてください
- ・かっこよく答えてください!!
- ・一回も披露したことのない豆知識
- ・ショボ短歌会
- ・いちばん失敗した人決定戦
- ・性格悪い人が優勝
- ・最速怪談選手権
- ・限定しりとり
- ・性格いい人が優勝
- ・これ何て呼びますか
- ・チョコミントアイス
- ・単二電池
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・ゴリラ向け動画サイト「ウホウホ動画」にありがちなこと
- ・泣きながら食べたご飯の思い出
- ・一番好きなみそ汁の具材は?
- ・人生で一番お金がなかったとき
- ・カラオケの鉄板ソング
- ・自分用のお土産
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Worksheets メソッドは失敗しま...
-
vba 2つの条件が一致したら...
-
VBA 何かしら文字が入っていたら
-
B列の最終行までA列をオート...
-
【Excel VBA】 B列に特定の文字...
-
IIF関数の使い方
-
Excelで、あるセルの値に応じて...
-
特定の列全体を選択or検索パネ...
-
複数の列の値を結合して別の列...
-
文字列の結合を空白行まで実行
-
GridViewの行の入れ替えについて
-
【VBA】複数行あるカンマ区切り...
-
【VBA】2つのシートの値を比較...
-
VBA初心者です 検索した数字の...
-
Cellsのかっこの中はどっちが行...
-
グリッドの列の最大値を求めたい。
-
rowsとcolsの意味
-
Excel VBA 他組み合わせと比較...
-
ExcelVBAで配列2つを結合させ...
-
Excelの列に入っている値を全て...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
B列の最終行までA列をオート...
-
Excelで、あるセルの値に応じて...
-
Cellsのかっこの中はどっちが行...
-
Worksheets メソッドは失敗しま...
-
vba 2つの条件が一致したら...
-
VBAのFind関数で結合セルを検索...
-
IIF関数の使い方
-
VBA 何かしら文字が入っていたら
-
URLのリンク切れをマクロを使っ...
-
【VBA】2つのシートの値を比較...
-
Changeイベントでの複数セルの...
-
VBAで指定範囲内の空白セルを左...
-
【Excel VBA】 B列に特定の文字...
-
データグリッドビューの一番最...
-
VBAで、特定の文字より後を削除...
-
文字列の結合を空白行まで実行
-
VBAを使って検索したセルをコピ...
-
二つのリストを比べて部分一致...
-
マクロについて。S列の途中から...
-
マクロ 最終列をコピーして最終...
おすすめ情報