こんにちは。
業務でエクセルを使っていたのですが、
あまりに毎回時間がかかってしまうため、
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で質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
好きな人を振り向かせるためにしたこと
大好きな人と会話のきっかけを少しでも作りたい、意識してもらいたい…! 振り向かせるためにどんなことをしたことがありますか?
-
歳とったな〜〜と思ったことは?
歳とったな〜〜〜、老いたな〜〜と思った具体的な瞬間はありますか?
-
自分独自の健康法はある?
こうしていると調子がいい!みたいな自分独自の健康法、こだわりはありますか?
-
この人頭いいなと思ったエピソード
一緒にいたときに「この人頭いいな」と思ったエピソードを教えてください
-
14歳の自分に衝撃の事実を告げてください
タイムマシンで14歳の自分のところに現れた未来のあなた。 衝撃的な事実を告げて自分に驚かせるとしたら何を告げますか?
-
vba 2つの条件が一致したらコピーして別シートに値のみ貼り付け
Visual Basic(VBA)
-
【VBA】特定の値が入った行をコピーして別シートに貼り付ける方法をおしえていただきたいです。
Excel(エクセル)
-
エクセルVBAで、条件に一致するセルへ移動
Excel(エクセル)
-
-
4
EXCEL VBAで文字列の検索とコピー
Excel(エクセル)
-
5
EXCEL VBA セルに既に入力されている文字に文字を追加する
Excel(エクセル)
-
6
VBAで検索して、行をコピー&追加したい
Excel(エクセル)
-
7
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
8
EXCEL VBAで、セルの文字列の前後に文字を入力する方法は?
その他(Microsoft Office)
-
9
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
10
Exel VBA 別ブックから該当データを検索し、必要なデータを取得する方法について
Visual Basic(VBA)
-
11
エクセルVBAで、ある指定した文字を含む行だけを選択したいのですが、、 例えば、1〜20行目までに"2161182"
Excel(エクセル)
-
12
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
13
数式による空白を無視して最終行を取得するマクロ
Excel(エクセル)
-
14
VBA Cのセルが空白でなかったら、Aのセルに順番に数値を入力
Visual Basic(VBA)
-
15
マクロで貼り付け位置を可変させる方法が知りたいです。
Excel(エクセル)
-
16
worksheetFunctionクラスのVlookupプロパティを取得できません エラーへの対応
Visual Basic(VBA)
-
17
【VBA】元のシート内の文字列を別シートと比較し、一致したら元のシートの別のセルへ転記する方法。
Excel(エクセル)
-
18
VBA 別ブックから条件に合うものを転記したいです
Visual Basic(VBA)
-
19
Excel VBAで同じフォルダ内のファイルを開くには?
Excel(エクセル)
-
20
エクセルVBAで、複数セルのデータをひとつのセルに改行してまとめたいのですか・・・
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・「みんな教えて! 選手権!!」開催のお知らせ
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~1/20】 追い込まれた犯人が咄嗟に言った一言とは?
- ・洋服何着持ってますか?
- ・みんなの【マイ・ベスト積読2024】を教えてください。
- ・「これいらなくない?」という慣習、教えてください
- ・今から楽しみな予定はありますか?
- ・AIツールの活用方法を教えて
- ・【選手権お題その3】この画像で一言【大喜利】
- ・【お題】逆襲の桃太郎
- ・自分独自の健康法はある?
- ・最強の防寒、あったか術を教えてください!
- ・【大喜利】【投稿~1/9】 忍者がやってるYouTubeが炎上してしまった理由
- ・歳とったな〜〜と思ったことは?
- ・ちょっと先の未来クイズ第6問
- ・モテ期を経験した方いらっしゃいますか?
- ・好きな人を振り向かせるためにしたこと
- ・【選手権お題その2】この漫画の2コマ目を考えてください
- ・【選手権お題その1】これってもしかして自分だけかもしれないな…と思うあるあるを教えてください
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excelで、あるセルの値に応じて...
-
vba 2つの条件が一致したら...
-
B列の最終行までA列をオート...
-
Worksheets メソッドは失敗しま...
-
データグリッドビューの一番最...
-
IIF関数の使い方
-
Cellsのかっこの中はどっちが行...
-
rowsとcolsの意味
-
VBAで指定範囲内の空白セルを左...
-
VBA 何かしら文字が入っていたら
-
VBAで、特定の文字より後を削除...
-
エクセル 2つの表の並べ替え
-
エクセルで結合セルがあるため...
-
VBAコンボボックスで選択した値...
-
VBA 値と一致した行の一部の列...
-
VBScriptでfindを使うには??
-
Excel VBA 同順位の順位補正に...
-
文字列の結合を空白行まで実行
-
Changeイベントでの複数セルの...
-
VBAを用いて条件付きの平均値、...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
B列の最終行までA列をオート...
-
Worksheets メソッドは失敗しま...
-
Excelで、あるセルの値に応じて...
-
Cellsのかっこの中はどっちが行...
-
vba 2つの条件が一致したら...
-
IIF関数の使い方
-
VBAのFind関数で結合セルを検索...
-
URLのリンク切れをマクロを使っ...
-
データグリッドビューの一番最...
-
文字列の結合を空白行まで実行
-
rowsとcolsの意味
-
VBAを使って検索したセルをコピ...
-
VBA 何かしら文字が入っていたら
-
Changeイベントでの複数セルの...
-
【Excel VBA】 B列に特定の文字...
-
【VBA】2つのシートの値を比較...
-
【Excel VBA】カンマと改行コー...
-
VBAで、離れた複数の列に対して...
-
VBAでのリスト不一致抽出について
-
エクセル 2つの表の並べ替え
おすすめ情報