POIでxlsmファイルを読み込み、データを書き込み、出力するWebアプリを作りました。
このxlsmには、ファイルオープン時に動作するVBAが実装済みです。(書き込まれたデータを元にグラフを作るVBA)
出力したxlsm・・①
出力したxlsmをVBA無効のまま開き、上書き保存したもの・・②
出力したxlsmをVBA無効のまま開き、VBAに適当に改行コードを入れて上書き保存したもの・・③
上記3つのxlsmをVBA有効として開いたとき、ファイルオープン時に動作するVBAの実行時間に大きな差があることに気づきました
①90秒
②60秒
③40秒
※時間はイメージしやすいように大まかです
※Excel2016です
VBA実行前の3つのxlsmをWinMergeのエクセルファイル比較をしましたが差異ありません。
VBA実行後の3つのxlsmをWinMergeのエクセルファイル比較をしましたが差異ありません。
なぜ上記のようにVBA実行時間に差異が出るのかご存じの方がおれば、ぜひ教えてくださいm(_ _)m
POI出力直後のファイルがExcelに最適化されておらず、いったんExcelで開いて上書き保存することで最適化され、その後実行されるVBAの実行時間が改善される、、、みたいな感じでしょうか?
あなたの回答
tips
プレビュー