
現在、Excel 2010 では、.xlsx ファイルとして作成し、VBA 関数またはサブルーチンを追加したワークブックを保存しようとすると、Excel は (遠回しに) .xlsm ファイルに変更するかどうかを尋ねるプロンプトを表示します。この質問に対するデフォルトの回答が「はい、保存したためにこのファイルで作業中に行ったすべてのプログラミング作業が削除されることは望ましくありません」であれば、これは問題になりませんが、積極的に「いいえ」ボタンをクリックするか、タブで移動する必要があります。そうしないと、.xlsx ファイルとして保存され、すべてのモジュールが失われます。
これは、デフォルトのオプションがデータを保存するのではなく削除することになっている、私が遭遇した数少ない状況の 1 つです。作業の一部が失われたのは主に私のせいであり、もっと注意する必要があることはわかっていますが、このメッセージを無効にしたり、何らかの方法でデフォルトを変更したりできるかどうかを本当に知りたいです。
答え1
あなたできるしかし、それは面倒で危険です。
- VBA に VBA の読み取り/書き込みを許可する (ファイル > オプション > セキュリティ センター > セキュリティ センターの設定 > マクロの設定 > VBA プロジェクト オブジェクト モデルへのアクセスを信頼する)
- 個人用マクロブックを作成します(まだ作成していない場合)
ThisWorkbook
個人用マクロ ワークブックのオブジェクトで、イベントを使用して+ を他のマクロにWorkbook_Open
マップします。(次のようになります)CtrlSApplication.OnKey "^s", "saveAsMacroIfMacrosExist"
- イベントを使用して
Workbook_BeforeClose
再度オフにします(Application.OnKey "^s"
) - 関数ではなくサブルーチンを個人用マクロブックのモジュールに記述してください。(これは読者の課題として残しておきますが、私はスニペットを見つけました。こここれは私がテストしなかったものですが、ワークブックにマクロが含まれているかどうかをテストすることになっています。
- ツールバーまたは「ファイル > 保存」の代わりにCtrl+を使用してファイルを保存します。S
重要なポイント: これには、VBA プロジェクト オブジェクト モデルへのアクセスを永続的に許可することが必要であり、これは一般的には好ましくありません。
答え2
これをワークブック レベルで変更することはできません。
ただし、Excel ですべてのマクロを常にデフォルトで有効にすることができます。
- [ファイル] > [オプション] をクリックします。
- [セキュリティ センター] と [セキュリティ センターの設定] をクリックします。
- マクロ設定をクリックし、すべてのマクロを有効にする
それはドキュメンテーション