ExcelマクロVBA練習問題解答 | 第43回.総合練習問題5回答 | Excelマクロ練習問題集、エクセルVBAの学習教材



最終更新日:2015-10-22

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

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


以下の表で問題です。



このシートは、「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に貼り付け

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


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






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

第50回.総合練習問題6回答
第67回.総合練習問題7回答
第78回.総合練習問題8回答
第81回.総合練習問題9回答
第86回.総合練習問題10回答
練習問題1(For〜Nextの練習)回答
練習問題2(最終行の取得の練習)回答

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

最後の空白(や指定文字)以降の文字を取り出す|エクセル関数超技(3月26日)
先頭の数値、最後の数値を取り出す|エクセル関数超技(3月26日)
Excelファイルを開かずにシート名をチェック|ExcelマクロVBAサンプル集(3月23日)
数式の参照しているセルを取得する|ExcelマクロVBAサンプル集(3月18日)
CSVの読み込み方法(改の改)|ExcelマクロVBAサンプル集(3月17日)
変数とプロシージャーの命名について|ExcelマクロVBA技術解説(2月12日)
ファイルの一覧取得・削除(File)|Google Apps Script入門(1月24日)
フォルダの一覧取得・作成・削除(Folder)|Google Apps Script入門(1月24日)
フォルダとファイルを扱う(DriveApp)|Google Apps Script入門(1月24日)
スプレッドシートが非常に遅い、高速化するには|Google Apps Script入門(1月17日)

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

1.最終行の取得(End,Rows.Count)|ExcelマクロVBA入門
2.RangeとCellsの使い方|ExcelマクロVBA入門
3.徹底解説(VLOOKUP,MATCH,INDEX,OFFSET)|エクセル関数超技
4.Range以外の指定方法(Cells,Rows,Columns)|ExcelマクロVBA入門
5.セルの参照範囲を可変にする(OFFSET,COUNTA,MATCH)|エクセル関数超技
6.セルのコピー&値の貼り付け(PasteSpecial)|ExcelマクロVBA入門
7.変数とデータ型(Dim)|ExcelマクロVBA入門
8.ひらがな⇔カタカナの変換|エクセル基本操作
9.CSVの読み込み方法|ExcelマクロVBAサンプル集
10.VBAのFindメソッドの使い方には注意が必要です|ExcelマクロVBA技術解説



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

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


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

    ↑ PAGE TOP