ExcelマクロVBA練習問題解答
第43回.総合練習問題5回答

Excelマクロ練習問題集、エクセルVBAの学習教材
最終更新日:2015-10-22

第43回.総合練習問題5回答

回答ページです、いわゆる百ます計算です



以下の表で問題です。


Excel解説

このシートは、「Sheet1」とし、別に「Sheet2」が存在します。


百マス計算のようなものです、交点のセルに掛け算を入れて下さい。


・「Sheet1」に計算式を埋めて下さい。


・「Sheet2」を、「Sheet1」と全く同じ状態にして下さい、
 ただし、「Sheet2」は計算式ではなく、計算結果の数値だけにして下さい。


では、始め


・・

・・・

・・・・

・・・・・


はい、終了



では、回答のサンプルマクロ

Sub 練習1()
  Sheets("Sheet1").Range("C3:L12").Value = "=C$2*$B3" '計算式設定
  Sheets("Sheet1").Cells.Copy Destination:=Sheets("Sheet2").Cells 'シートの全セルコピー
  Sheets("Sheet2").Range("C3:L12").Value = Sheets("Sheet1").Range("C3:L12").Value '値だけのコピー
End Sub


この3行で完成します。


計算式を入れる所は、1つづつ入れるなら、

Sub 練習2()
  Dim i As Long, j As Long
  For i = 3 To 12
    For j = 3 To 12
      Cells(i, j).FormulaR1C1 = "=R2C*RC2"
    Next j
  Next i
  Sheets("Sheet1").Cells.Copy Destination:=Sheets("Sheet2").Cells
  Sheets("Sheet2").Range("C3:L12").Value = Sheets("Sheet1").Range("C3:L12").Value
End Sub

こんな感じでも良いですが、今回の場合は一度に入れた方がよいです。


Sheets("Sheet1").Cells.Copy Destination:=Sheets("Sheet2").Cells

ここが少々解りづらいかもしれませんが、


Cellsに引数を指定しないと、シートの全セルになります。


そういえば、Cellsの説明の時に、抜けていたようです、すみません。


Sheets("Sheet2").Range("C3:L12").Value = Sheets("Sheet1").Range("C3:L12").Value


Sheets("Sheet2").Range("C3:L12").Value = Sheets("Sheet2").Range("C3:L12").Value

と同一シートでも良いです。



このマクロの3行は、手動でやった場合と同じです。


・範囲選択して、一括で計算式を入れる(絶対参照・相対参照を注意)

・シート全体を選択しコピー、Sheet2に貼り付け

・計算結果の部分を、コピー&値の貼り付け


これを、素直にマクロに書くとこうなります、というサンプルです。







同じテーマ「マクロVBA練習問題解答」の記事

総合練習問題2回答
総合練習問題3回答
総合練習問題4回答
総合練習問題5回答
総合練習問題6回答
総合練習問題7回答
総合練習問題8回答
総合練習問題9回答
総合練習問題10回答
練習問題1(For〜Nextの練習)回答
練習問題2(最終行の取得の練習)回答

新着記事NEW ・・・新着記事一覧を見る

クラスとCallByNameとポリモーフィズム(多態性)|VBA技術解説(4月6日)
VBAでのタイマー処理(SetTimer,OnTime)|VBA技術解説(4月3日)
クラスとイベントとマルチプロセス並列処理|VBA技術解説(4月2日)
エクセルの日付と時刻のまとめ|エクセル関数超技(3月6日)
Excelシートの複雑な計算式を解析するVBA|VBAサンプル集(2月18日)
VBAクラスの作り方:独自Rangeっぽいものを作ってみた|VBA技術解説(2月16日)
VBAクラスの作り方:列名のプロパティを自動作成する|VBA技術解説(2月14日)
VBAクラスの作り方:列名の入力支援と列移動対応|VBA技術解説(2月11日)
クラスを使って他ブックのイベントを補足する|VBA技術解説(2月6日)
Excelアドインの作成と登録について|VBA技術解説(2月3日)

アクセスランキング ・・・ ランキング一覧を見る

1.ひらがな⇔カタカナの変換|エクセル基本操作
2.最終行の取得(End,Rows.Count)|VBA入門
3.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
4.Range以外の指定方法(Cells,Rows,Columns)|VBA入門
5.RangeとCellsの使い方|ExcelマクロVBA入門
6.変数とデータ型(Dim)|ExcelマクロVBA入門
7.マクロって何?VBAって何?|ExcelマクロVBA入門
8.繰り返し処理(For Next)|ExcelマクロVBA入門
9.とにかく書いて見よう(Sub,End Sub)|VBA入門
10.セルに文字を入れるとは(Range,Value)|VBA入門



  • >
  • >
  • >
  • 総合練習問題5回答

    このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


    記述には細心の注意をしたつもりですが、
    間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
    なお、掲載のVBAコードは自己責任で使ってください。万一データ破損等の損害が発生しても責任は負いません。






    このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。

    本文下部へ