練習問題28(シートを別ブックにして値のみにする)解答
マクロVBA練習問題28の解答ページです。
マクロVBA練習問題
Sheet1だけを別ブックにして、計算式を抜き(値だけに)にしてから保存して下さい。
作成したブックの保存先は、アクティブブックと同一フォルダとし、ブック名はシート名と同一にして下さい。
練習問題用のExcelファイル
シンキングタイム
シンキングタイム終了
書くべきマクロVBAが分からない時は、
ここでじっくり勉強してから再チャレンジしてください。
マクロVBA練習問題解答
Sub 練習問題28()
Dim wb1 As Workbook, ws1 As Worksheet
Dim wb2 As Workbook, ws2 As Worksheet
Set wb1 = ActiveWorkbook
Set ws1 = wb1.Worksheets("Sheet1")
ws1.Copy
Set wb2 = ActiveWorkbook
Set ws2 = wb2.ActiveSheet
ws2.UsedRange.Value = ws2.UsedRange.Value
If CInt(Application.Version) < 12 Then
wb2.SaveAs ThisWorkbook.Path & "\" & ws2.Name & ".xls"
Else
wb2.SaveAs ThisWorkbook.Path & "\" & ws2.Name & ".xlsx"
End If
wb2.Close
End Sub
今回の肝は、
ws2.UsedRange.Value = ws2.UsedRange.Value
これで、当該シートの数式は消えて値のみになります。
ここで、
ws2.Cells.Value = ws2.Cells.Value
これでも良さそうですが、
Excel2007以降の形式では、多くのPCでメモリ不足が出てしまいます。
つまり、100万行*1万列以上の範囲指定は、ちょっときびしいということです。
また、
Cells.Copy
Cells.PasteSpecial Paste:=xlPasteValues
これでも良いのですが、.Copyではクリップボードが使用されますし、
何より、値だけにするなら今回提示のVBAコード方がスマートだと思います。
オブジェクト変数(Workbook,Worksheet)の使い方は、人により好みが分かれる部分ですが、
今回は、全てオブジェクト変数に入れてから処理するようにしてみました。
Withを使った方が見やすいと感じる人も多いかと思います。
自分なりに書きやすく読みやすいと思うVBAコードで書いてみてください。
例えば、
Worksheets("Sheet1").
このピリオドを入力しても、候補表示されませんが、
Set ws1 = wb1.Worksheets("Sheet1")
ws1.
このピリオドを入力した時点では候補表示されるようになります。
つまり、オブジェクト型が確定されている事になります。
オブジェクト変数を上手く使えるようになることは、VBA上達の要でもあります。
同じテーマ「マクロVBA練習問題解答」の記事
練習問題23(総合練習5)解答
練習問題24(再帰呼出し)解答
練習問題25(各種VBA関数)解答
練習問題26(全シート処理とハイパーリンク)解答
練習問題27(データ分割し別ブック保存)解答
練習問題28(シートを別ブックにして値のみにする)解答
練習問題29(ロット引き当て)解答
練習問題30(マトリックス→リスト形式)解答
練習問題31(セル結合を解除して値を埋める)解答
練習問題32(連続数値部分を取り出し記号で連結)解答
初級脱出10問パック解答
新着記事NEW ・・・新着記事一覧を見る
第5章:AI×VBAでつまづかない!トラブルシューティングとAIとの付き合い方
|生成AI活用研究(2025-05-20)
第4章:【事例で学ぶ】AIとVBAでExcel作業を劇的に効率化する!
|生成AI活用研究(2025-05-20)
第3章:AIを「自分だけのVBA先生」にする!質問・相談の超実践テクニック|生成AI活用研究(2025-05-19)
第2章 VBAって怖くない!Excelを「言葉で動かす」(超入門)|生成AI活用研究(2025-05-18)
第1章:AIって一体何?あなたのExcel作業をどう変える?(AI超基本)|生成AI活用研究(2025-05-18)
AI時代のExcel革命:AI×VBAで“書かない自動化”超入門|生成AI活用研究(2025-05-17)
Geminiと100本ノック 23本目:シート構成の一致確認|生成AI活用研究(5月16日)
AIが問う出版の未来は淘汰か進化か:AIと書籍の共存の道とは|生成AI活用研究(2025-05-16)
Geminiと100本ノック 22本目:FizzBuzz発展問題|生成AI活用研究(5月15日)
すぐに使える!生成AI プロンプト作成 実践ガイド|生成AI活用研究(2025-05-15)
アクセスランキング ・・・ ランキング一覧を見る
1.最終行の取得(End,Rows.Count)|VBA入門
2.繰り返し処理(For Next)|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
5.ひらがな⇔カタカナの変換|エクセル基本操作
6.RangeとCellsの使い方|VBA入門
7.メッセージボックス(MsgBox関数)|VBA入門
8.セルのクリア(Clear,ClearContents)|VBA入門
9.FILTER関数(範囲をフィルター処理)|エクセル入門
10.条件分岐(Select Case)|VBA入門
- ホーム
- マクロVBA入門編
- マクロVBA練習問題解答
- 練習問題28(シートを別ブックにして値のみにする)解答
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。