こんにちは、エクセル365を使っています。
範囲
Range("V2:V8,W2:W7,X2:X6,Y2:Y5,Z2:Z4,AA2:AA3,AB2")
の中の値をAC2に値として貼り付けたいのですが、一番簡単な方法はどういったものでしょうか。
数分おきにこの中の特定の数値をAC2に転記する作業があり、かと言って一つ一つにマクロを設定するのもなんだかスマートでは無いような気がします。
詳しい方、教えて頂けませんか、よろしくお願い致します。
1回に、1つ選んでペーストする感じです。
ちなみにこのシートには既にマクロが書いてあり、以下のような物です。
Private Sub Worksheet_Change(ByVal Target As Range)
Dim i As Long, j As Long, js As Long
If Intersect(Target, Range("R17:S50,AC1")) Is Nothing Or Target.Count > 1 Then Exit Sub
If Target.Row = 1 Then
If Target.Value <> "" Then
Range("AC42").End(xlUp).Offset(1) = Target.Value
Range("AC1").ClearContents '//←AC1セルのデータを残す場合はこの行は不要★//
Range("AC2:AC41").Sort key1:=Range("AC2"), order1:=xlAscending, Header:=xlNo
End If
Else '//★//
Range("V17:U50").ClearContents
For i = 17 To 50
If Cells(i, "R") <> "" Then
For j = i To 50
If Cells(j, "S") <> "" Then
If Application.CountIf(Range("X17:X50"), Cells(i, "R") & Cells(j, "S")) > 0 Then
Cells(Cells(Rows.Count, "V").End(xlUp).Row + 1, "V") = Cells(j, "S") & Cells(i, "R")
Else
Cells(Cells(Rows.Count, "U").End(xlUp).Row + 1, "U") = Cells(i, "R") & Cells(j, "S")
End If
End If
Next
End If
If Cells(i, "S") <> "" Then
For js = i To 50
If Cells(js, "R") <> "" Then
If Application.CountIf(Range("X17:X50"), Cells(i, "S") & Cells(js, "R")) > 0 Then
Cells(Cells(Rows.Count, "U").End(xlUp).Row + 1, "U") = Cells(js, "R") & Cells(i, "S")
Else
Cells(Cells(Rows.Count, "V").End(xlUp).Row + 1, "V") = Cells(i, "S") & Cells(js, "R")
End If
End If
Next
End If
Next
Call Range("U17:U50").Sort(key1:=Range("U17"), order1:=xlAscending)
Call Range("V17:V50").Sort(key1:=Range("V17"), order1:=xlAscending)
End If
End Sub
Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
If Intersect(Target, Range("R17:S24,AC2:AC50")) Is Nothing Then Exit Sub
Cancel = True
Target.ClearContents
End Sub
No.2ベストアンサー
- 回答日時:
#1です。
思った通りの動きで良かったです。
色々あると思いますが、私なりに理解しました。
頑張ってくださいね。。
No.1
- 回答日時:
こんばんは、
いつずつ選んでAC2に入力したいと言う事で良いのでしょうか?
幸い、Changeイベントには絡まないようなので、対象範囲をダブルクリックで
AC2セルに入力します。AC2セルは、ダブルクリックの違う処理が設定されているので
AC2セルをダブルクリックするとクリアーされると思います。
果たして仕様に合うのかわかりませんが、
示されているPrivate Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)を下記に書き換えます。
Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
If Intersect(Target, Range("R17:S24,AC2:AC50,V2:V8,W2:W7,X2:X6,Y2:Y5,Z2:Z4,AA2:AA3,AB2")) Is Nothing Then Exit Sub
Cancel = True
If Not Intersect(Target, Range("V2:V8,W2:W7,X2:X6,Y2:Y5,Z2:Z4,AA2:AA3,AB2")) Is Nothing Then
Range("AC2").Value = Target.Value
Exit Sub
End If
Target.ClearContents
End Sub
回答は、参考なので、
判らない処理をどんどん付け足してプログラムを作って大丈夫かと
心配ですが、ここまで来たら、その時は、覚悟して学習してくださいね。
わっ、ありがとうございます。
思った通りの動きで嬉しいです。
ちなみにAC1なのにAC2って書いてしまう私って、、、落ち着きがないと言うかなんと言うか(笑)
マクロの勉強でしょう?
本当はやったほうが良いのですが、一人である事に挑戦してまして、正直時間が取れないので、みなさんに助けられております。
ほんとありがとうございます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) VBAの指示の内容 昨日こちらでご教示頂いたのですが初心者な為、一つ一つの指示が何をやっているのかわ 2 2022/10/25 18:08
- Visual Basic(VBA) VBA処理追加 こちらでご教示頂いたのですが回答完了させてしまいましたのでこちらからまた質問させてく 2 2022/10/27 09:57
- Excel(エクセル) VBAについて 3 2022/06/19 18:19
- Excel(エクセル) エクセルVBAでオブジェクトが必要です 2 2022/09/10 16:37
- Visual Basic(VBA) excel VBA if文について 3 2022/03/27 17:42
- Visual Basic(VBA) VBA 請求書自動作成 3 2022/04/24 01:58
- Visual Basic(VBA) ローマ字、ハイフン付きの並び替え ローマ字抽出方法 Excelマクロ 4 2022/04/01 14:10
- Excel(エクセル) マクロで最終行から上に検索を逆にしたい 1 2022/05/17 18:27
- Excel(エクセル) マクロで列を加えたら上手くいかなくなりました。 2 2022/05/23 17:59
- Excel(エクセル) VBAで組み合わせ算出やCOUNTIFSの処理を高速化したいです。 4 2022/04/07 02:38
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBA ユーザーフォーム ボタンク...
-
screenupdatingが機能しなくて...
-
Excelで指定した日付から過去の...
-
特定のセルが空白だったら、そ...
-
i=cells(Rows.Count, 1)とi=cel...
-
ExcelVBAを使って、値...
-
Excelのハイパーリンクにマクロ...
-
スプレッドシートをGASでセル保...
-
【Excel】指定したセルの名前で...
-
エクセルvba:自己セルの情報取...
-
【VBA】指定したセルと同じ値で...
-
EXCELで変数をペーストしたい
-
エクセルVBA MATCHをユーザー...
-
RC表示に変数を入れる
-
エクセルマクロで結合セルに格...
-
VBAを使用した時間管理
-
vbsのセル値の取得について
-
EXCELのVBA-フィルタ抽出後の...
-
Sub 要具ライフ() ActiveSheet....
-
クリックされたセルの位置を取...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ExcelVBAを使って、値...
-
特定のセルが空白だったら、そ...
-
【Excel VBA】指定行以降をクリ...
-
i=cells(Rows.Count, 1)とi=cel...
-
【Excel】指定したセルの名前で...
-
Excelで指定した日付から過去の...
-
特定の文字を条件に行挿入とそ...
-
Excel VBA、 別ブックの最終行...
-
EXCELで変数をペーストしたい
-
Excelのプルダウンで2列分の情...
-
TODAY()で設定したセルの日付...
-
Excel vbaで特定の文字以外が入...
-
screenupdatingが機能しなくて...
-
DataGridViewの各セル幅を自由...
-
Sub 要具ライフ() ActiveSheet....
-
【EXCEL VBA】Range("A:A").Fi...
-
VBAを使用した時間管理
-
VBAでセルをクリックする回...
-
セル色なしの行一括削除
-
エクセルVBAでコピーして順...
おすすめ情報