こんにちは、エクセル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で質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
許せない心理テスト
私は「あなたの目の前にケーキがあります。ろうそくは何本刺さっていますか」と言われ「12本」と答えたら…
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
エクセル クリックした値を転記
Excel(エクセル)
-
VBA セルをダブルクリック→違うセルに値をコピー
Excel(エクセル)
-
エクセルでセルをダブルクリックしたらそのブックの別のシートに飛ぶ動作
Excel(エクセル)
-
-
4
エクセルVBAでダブルクリックをしたらA列のデータが別シートに転記されるにはどうしたらよいですか?
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
特定のセルが空白だったら、そ...
-
ExcelVBAを使って、値...
-
”戻り値”が変化したときに、マ...
-
Excelで指定した日付から過去の...
-
EXCELで変数をペーストしたい
-
セル色なしの行一括削除
-
TODAY()で設定したセルの日付...
-
【Excel】指定したセルの名前で...
-
VBからEXCELのセルの値を取得す...
-
i=cells(Rows.Count, 1)とi=cel...
-
Application.Matchで特定行の検索
-
連続する複数のセル値がすべて0...
-
screenupdatingが機能しなくて...
-
Excel2003 複数セル1列の入力済...
-
Excelのプルダウンで2列分の情...
-
Excel VBAで、 ヘッダーへのセ...
-
VBA実行後に元のセルに戻りたい
-
DataGridViewのセルのItem設定...
-
Excel ユーザーフォームをモー...
-
VBAでセル同士を比較して色付け
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
i=cells(Rows.Count, 1)とi=cel...
-
ExcelVBAを使って、値...
-
【Excel VBA】指定行以降をクリ...
-
特定のセルが空白だったら、そ...
-
EXCELで変数をペーストしたい
-
Excelで指定した日付から過去の...
-
VBAの間違い教えて下さい
-
【Excel】指定したセルの名前で...
-
Excelのプルダウンで2列分の情...
-
エクセルVBAでコピーして順...
-
Excel vbaで特定の文字以外が入...
-
Excel VBA、 別ブックの最終行...
-
【VBA】指定したセルと同じ値で...
-
特定の文字を条件に行挿入とそ...
-
TODAY()で設定したセルの日付...
-
screenupdatingが機能しなくて...
-
VBA初心者です。次のVBAコード...
-
指定した条件で行セルを非表示...
-
VBAでセルをクリックする回...
-
DataGridViewの各セル幅を自由...
おすすめ情報