
こんにちは。
業務でエクセルを使っていたのですが、
あまりに毎回時間がかかってしまうため、
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も見ています
-
プロが教えるわが家の防犯対策術!
ホームセキュリティのプロが、家庭の防犯対策を真剣に考える 2組のご夫婦へ実際の防犯対策術をご紹介!どうすれば家と家族を守れるのかを教えます!
-
vba 2つの条件が一致したらコピーして別シートに値のみ貼り付け
Visual Basic(VBA)
-
VBAで検索して、行をコピー&追加したい
Excel(エクセル)
-
エクセル VBA find は別シートを検索できますでしょうか?
Excel(エクセル)
-
4
VBAで繰り返しコピーしながら下へ移動させる方法
Excel(エクセル)
-
5
Exel VBA 別ブックから該当データを検索し、必要なデータを取得する方法について
Visual Basic(VBA)
-
6
EXCEL VBAで文字列の検索とコピー
Excel(エクセル)
-
7
エクセルVBAで、条件に一致するセルへ移動
Excel(エクセル)
-
8
[初心者です]VBAで指定列からAを検索し、発見したら隣のセルに値0を入れるマクロ。
Access(アクセス)
-
9
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
10
【VBA】特定の値が入った行をコピーして別シートに貼り付ける方法をおしえていただきたいです。
Excel(エクセル)
-
11
VBAで条件が一致する行をコピーしその1つ下へ挿入
Excel(エクセル)
-
12
VBAで条件が一致する行のデータを別シートに抽出
Excel(エクセル)
-
13
VBA 条件が一致した場合のみコピーする
その他(ビジネス・キャリア)
-
14
【VBA】指定した検索条件に一致したら別シートに転記したい
Visual Basic(VBA)
-
15
別シートの最終行に貼り付けするマクロを教えてください。 シートYのE3からE15までをコピー シート
Excel(エクセル)
-
16
【VBA】指定したセルと同じ値で、別シートにあるセルに移動するには?
Visual Basic(VBA)
-
17
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
18
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
19
別のシートから値を取得するとき
Visual Basic(VBA)
-
20
VBAで他のシートの特定の列を検索・コピーし、貼り付ける。
PowerPoint(パワーポイント)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
人気Q&Aランキング
-
4
複数の列の値を結合して別の列...
-
5
VBマクロ 色の付いたセルを...
-
6
VBAの構文 3列置きにコピーし...
-
7
自動で採番と日付を入力するマクロ
-
8
Cellsのかっこの中はどっちが行...
-
9
Worksheets メソッドは失敗しま...
-
10
VBAを用いて条件付きの平均値、...
-
11
VBAで別のブックの値をVlookup...
-
12
DataGridViewに空白がある場合...
-
13
Changeイベントでの複数セルの...
-
14
VBA 列が空白なら別のマクロへ...
-
15
VBAを使って検索したセルをコピ...
-
16
列の最終行までのセルと1つ隣の...
-
17
DataGridViewにリンク列の追加...
-
18
ダブルクリック 条件 分岐
-
19
VBAで、離れた複数の列に対して...
-
20
SetDlgItemTextの使い方について
おすすめ情報
公式facebook
公式twitter