エクセルVBAについてご教示お願いします。
指定されたセルに特定の文字が入力された際に
特定のセル範囲からコピーしたセルの貼り付けを行いたいのですが
うまくいきません。
A2に入力された清掃作業、工事作業、除草作業の3つの内
・清掃作業を入力した場合はA17:F24のセルをA4に貼り付け。
・工事作業を入力した場合はA27:F43のセルをA4に貼り付け
・除草作業を入力した場合はH17:M33のセルをA4に貼り付け
VBAは全く触ったことが無く探り探りで書いてみたのですが
多分めちゃくちゃだと思います・・・
正しいやり方を教えて頂ければ幸いです。
' 清掃作業
If Cells(2, "A").Value = "清掃作業" Then
Range("A17:F24").Copy Range("A4")
End Sub
' 工事作業
ElseIf Cells(2, "A").Value = "工事作業" Then
Range("A27:F43").Copy Range("A4")
End Sub
' 除草作業
ElseIf Cells(2, "A") >= "除草作業" Then
Range("H17:M33").Copy Range("A4")
End Sub
No.6ベストアンサー
- 回答日時:
もしも、次のコードを実行すると
1)Range("A27:F43").Copy Range("A4")
2)Range("H17:M33").Copy Range("A4")
Range("A4:F20")が書き換わります。
もしも、Range("A17:F20")にデータなどが入っていると、
そこは 次の範囲が貼り付けられた状態になります。
1)Range("A40:F43")
2)Range("H30:M33")
その後に、
Range("A17:F24").Copy Range("A4")をやって、
期待した結果になるのか、確認した方がイイと思います。
No.5
- 回答日時:
もしも、次のコードを実行すると
1)Range("A27:F43").Copy Range("A4")
2)Range("H17:M33").Copy Range("A4")
Range("A4:F20")が書き換わります。
もしも、Range("A17:F20")にデータなどが入っていると、
そこは 次の範囲が貼り付けられた状態になります。
1)Range("A40:F43")
2)Range("H30:M33")
その後に、
Range("A17:F24").Copy Range("A4")をやって、
期待した結果になるのか、確認した方がイイと思います。
No.4
- 回答日時:
こんにちは。
「EXELEマクロで入力規則を使ったコピペ方法 」
こちらをみて気がついたことですが、やはり『コンボボックス』のことではないでしょうか?
そのために、3つ別れているのでしょうね。
初心者コースとしては、ActiveX コントロールで、開発タブから、コントロールの中の挿入から、ActiveX コントロール-コンボボックスを選びます。
画面にドラッグしたら、形ができます。
次に、コマンドボタンが必要ですが、同じActiveX コントロールの中で、コマンドボタンを選択して、画面にドラックします。そして、そのボタンをダブルクリックをすると、新しい画面が出てきますから、そこに、
Private Sub CommandButton1_Click()
If ComboBox1.ListCount = 0 Then 'コンボボックスが空の場合
Call Auto_Open
End If
Range("A4").CurrentRegion.ClearContents
Select Case ComboBox1.ListIndex '選択肢
Case 0
Range("A17:F24").Copy Range("A4")
Case 1
Range("A27:F43").Copy Range("A4")
Case 2
Range("H17:M33").Copy Range("A4")
Case Else
End Select
ComboBox1.Text = "選択してください。"
End Sub
その画面から、上のメニューの挿入-標準モジュールをクリックしますと、画面が出てきますから、
Sub Auto_Open() '起動した時に設定するマクロ
With Worksheets("Sheet1") 'シート名は任意。
.ComboBox1.AddItem "清掃作業"
.ComboBox1.AddItem "工事作業"
.ComboBox1.AddItem "除草作業"
.ComboBox1.Text = "選択してください。"
End With
End Sub
このようにすると、以下のように出来上がります。
私が別で質問した所から追いかけて回答してくださりありがとうございます。
コンボボックスというものでもできるのですね!
今回は入力規則で作ってしまった為、教えて頂いた情報も元に
コンボボックスで作ってみたいと思います。
ありがとうございます。
No.3
- 回答日時:
以下のようにしてください。
------------------------------------------------------
' 清掃作業
If Cells(2, "A").Value = "清掃作業" Then
Range("A17:F24").Copy Range("A4")
' 工事作業
ElseIf Cells(2, "A").Value = "工事作業" Then
Range("A27:F43").Copy Range("A4")
' 除草作業
ElseIf Cells(2, "A") = "除草作業" Then
Range("H17:M33").Copy Range("A4")
End If
--------------------------------------------
No.2
- 回答日時:
ただ、《A4:F20に、(A17:F24)(A27:F43)(H17:M33)にある値を、A2の値によって切り替えて表示させたい》のであれば、マクロを使わずに、A4:F20に関数を入れて表示させたらいかがでしょうか。
VBAでやるなら、チェンジイベント機能を使う必要がありそうです。
関数なら、=INDEX(INDIRECT(A2),1,1)のようなのでなんとか済ませて、単純そうです。
範囲の名前定義を使えば、IF文もいらないでしょう。
A2に、"未指定"も選択可能なリストの入力規制をつくり、一見無用な空白で良いセルには、" "(スペース)を入力しておけば済むと思います。
範囲が、(A17:F24)=8×6、(A27:F43)=17×6、(H17:M33)=17×6と一致してないですが、シート設計を直して良いのならば、単純に作り込んだ方が、数式が単純で済みます。
No.1
- 回答日時:
合ってますよ。
但し End Sub → End If に修正して下さい。
またElseIfの前にはEnd Ifは入れない
' 清掃作業
If Cells(2, "A").Value = "清掃作業" Then
Range("A17:F24").Copy Range("A4")
' 工事作業
ElseIf Cells(2, "A").Value = "工事作業" Then
Range("A27:F43").Copy Range("A4")
' 除草作業
ElseIf Cells(2, "A") >= "除草作業" Then
Range("H17:M33").Copy Range("A4")
End If
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
- Excel(エクセル) VBA 特定の列に入っているテキストをコピペ 2 2023/06/14 11:24
- Visual Basic(VBA) VBAで列を削除 3 2023/02/01 11:00
- Visual Basic(VBA) [Excel VBA] このコードでは行の挿入や行の消去をすると13のエラーが出てしまう。 3 2022/12/09 00:29
- Visual Basic(VBA) excel2021で実行できないマクロ。どこを直したらいいのか 2 2022/03/28 03:40
- Visual Basic(VBA) VBA Userformで一部別シートに転記がしたいのですが 2 2023/05/24 13:08
- Excel(エクセル) 日付で矢印マクロ 4 2023/07/25 16:47
- Visual Basic(VBA) エクセルVBA ダブルクリックしたら色反転を指定したセルのみにしたい 2 2022/04/06 12:52
- Excel(エクセル) 2つのVBAを一緒にしたら機能しなくなりました(エクセル) 7 2022/06/02 12:41
- Visual Basic(VBA) エクセルで、1つのセルで上書き足し算して セルの範囲を指定できますか? パソコン初心者です。 お時間 3 2023/07/05 06:13
このQ&Aを見た人はこんなQ&Aも見ています
-
【お題】NEW演歌
【大喜利】 若い人に向けたことは分かるけど、それはちょっと寄せ過ぎて変になってないか?と思った演歌の歌詞
-
これ何て呼びますか
あなたのお住いの地域で、これ、何て呼びますか?
-
「覚え間違い」を教えてください!
私はかなり長いこと「大団円」ということばを、たくさんの団員が祝ってくれるイメージで「大円団」だと間違えて覚えていました。
-
【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
【お題】 ・買ったばかりの自転車を分解してひと言
-
好きな「お肉」は?
牛肉、豚肉、鶏肉、ラム肉、クマやシカの狩猟肉……。 いろ〜んな肉が食べられるようになりましたよね。 あなたがこれまで食べて「これはうまい!」とか「なんじゃこりゃ!」と好きになったお肉を教えてください。
-
VBA 条件が一致した場合のみコピーする
その他(ビジネス・キャリア)
-
【VBA】特定列に文字が入っていたらそのセル行をコピーしてマスターブックの同じ行に貼り付けたい
その他(Microsoft Office)
-
【VBA】特定の値が入った行をコピーして別シートに貼り付ける方法をおしえていただきたいです。
Excel(エクセル)
-
-
4
ExcelVBAを使って、値がある場合は作業を繰り返し実行するプログラムを作成したい。
Visual Basic(VBA)
-
5
vba 2つの条件が一致したらコピーして別シートに値のみ貼り付け
Visual Basic(VBA)
-
6
VBAで繰り返しコピーしながら下へ移動させる方法
Excel(エクセル)
-
7
ある条件を満たすセルに対応する行のセル内容をコピーして・・
Visual Basic(VBA)
-
8
VBA Cのセルが空白でなかったら、Aのセルに順番に数値を入力
Visual Basic(VBA)
-
9
【VBA】特定の条件でセルをコピー
Visual Basic(VBA)
-
10
エクセルVBAでセルに入力したパスでブックを開く
Excel(エクセル)
-
11
【VBA】特定の文字が入っている行の一部を抽出して別シートコピーするには
Visual Basic(VBA)
-
12
VBA 空白行に転記する
Visual Basic(VBA)
-
13
マクロ 最終列をコピーして最終列の次の列に挿入する
Visual Basic(VBA)
-
14
エクセルVBAでコピーして順番に張り付けをしたい!
Visual Basic(VBA)
-
15
繰り返し1行~28行までを順順にコピーする方法
Visual Basic(VBA)
-
16
VBAを使って検索したセルをコピーして別の場所に貼り付ける。
Visual Basic(VBA)
-
17
EXCEL あるセルに数字が入力されれば既存マクロ実行させたい
Excel(エクセル)
-
18
同じ作業を複数のシートに実行させるにはどうしたらいいのでしょうか
Visual Basic(VBA)
-
19
エクセルvba (ByVal Target As Range)について
Excel(エクセル)
-
20
エクセルVBAで、ある指定した文字を含む行だけを選択したいのですが、、 例えば、1〜20行目までに"9683313"
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・ハマっている「お菓子」を教えて!
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
仕事において、「(ある作業を)...
-
製造業におけるSV派遣てどうい...
-
カブの葉は、アク抜き必要です...
-
一人残業または一人休日出勤っ...
-
照明器具交換 活線作業について
-
【画像あり】割りピンを簡単に...
-
特殊土木作業員ってなんですか?
-
ある動作が「ひとまず終わった...
-
重労働
-
土木積算「潮間作業」について
-
現業職と技能職の違い
-
「TT」とはどういう意味でしょ...
-
エクセルVBAのIFを使ったコピペ
-
鉄粉、粉塵について
-
実作業はどんな意味ですか?
-
ACCESS2007 レポートデザインビ...
-
合帳(あいちょう)とは言わな...
-
「作業の指示、ありがとうござ...
-
客先都合による待機時間の費用請求
-
迷惑コンクリートミキサー
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
仕事において、「(ある作業を)...
-
製造業におけるSV派遣てどうい...
-
照明器具交換 活線作業について
-
一人残業または一人休日出勤っ...
-
実作業はどんな意味ですか?
-
ある動作が「ひとまず終わった...
-
カブの葉は、アク抜き必要です...
-
建設工事 土日祝 時間 法律
-
特殊土木作業員ってなんですか?
-
VectorWorks の作業画面の取り...
-
土木積算「潮間作業」について
-
「作業の指示、ありがとうござ...
-
作業をしながら数を数え続ける...
-
承認者が照査を兼ねていたら照...
-
鉄粉、粉塵について
-
エクセルVBAのIFを使ったコピペ
-
迷惑コンクリートミキサー
-
作業する人を「ボウシン」って
-
SB3UGSでのfbxで出力した際fbx...
-
重労働
おすすめ情報