目次:
- すべての変数を宣言しますか?
- VBAプロジェクトをパスワードで保護するだけで安全ですか?違う。
- アプリケーションが満足のいく結果を得たら、整理する必要があります。コードハウスキーピングタスクには、以下が含まれます。
- 分かりにくいプログラムを作りたいですか?それを達成するための効率的な方法は、あなたのコードをすばらしいひとつの大きな手順の中に置くことです。このプログラムをもう一度やり直して変更を加えたら、間違いを犯して細かいバグを導入する必要があります。
- Excelは驚くほど多彩なプログラムですが、すべてに適していません。新しいプロジェクトを開始する準備ができたら、時間をかけてすべてのオプションを検討してください。古い言葉を言い換えると、「あなたが知っていることはすべてExcel VBAだと、すべてがVBAマクロのように見えます。 "
- 知っているように、Excelではマクロを無効にしたブックを開くことができます。実際には、Excelの最新バージョンのデザイナーが
- あなたのコードが他のExcelバージョンで動作するとは思わない
- Excelには便利な互換性チェッカーが含まれています(ファイル→情報→問題のチェック→互換性のチェックを選択します)が、ブックをチェックしてVBAコードを無視します。アプリケーションが作成したもの以外のバージョンで動作することを確認する唯一の方法は、それらのバージョンでテストすることです。
- たとえば、あなたが唯一のユーザであれば、エラー処理でもっと甘くすることができます。エラーが発生した場合は、どこを見て修正することができるかを知ることができます。他の誰かがあなたのアプリを使用していて、同じエラーが表示された場合、彼または彼女は不運になります。また、自分のアプリケーションを使って作業しているときは、通常は指示なしに取得できます。
ビデオ: 楽ちん思いやりシフト製品紹介 2024
ここでは、独自のExcel VBAソリューションの開発を開始する際に考慮する必要があるアドバイスがあります。これらのガイドラインに従うことは、(プログラミングの)トラブルからあなたを守るための万能薬ではありませんが、それに続くと、他の人が遭遇した落とし穴を避けることができます。
すべての変数を宣言しますか?
使いやすさ:使いたい変数を宣言するという面倒な手間をかけずに、VBAコードの入力を開始するだけです。 Excelでは、宣言されていない変数を使用することができますが、単に問題を尋ねるだけです。
<! - 1 - >VBAプログラミングの最初の命令は次のとおりです。
あなたはすべての変数を宣言します。
自己規律がない場合は、モジュールの上部に「Option Explicit」ステートメントを追加します。そうすれば、宣言されていない変数が1つ以上含まれていても、コードは実行されません。すべての変数を宣言するのは1つだけの利点があります。数秒間節約できます。しかし、宣言されていない変数を使用すると、最終的にはあなたのところに戻ってきます。
<!パスワードをセキュリティと混同しないでください。VBAプロジェクトをパスワードで保護するだけで安全ですか?違う。
VBAパスワードを使用すると、ほとんどのカジュアルなユーザーはあなたのコードを見ることができなくなります。しかし、誰か
本当に がそれをチェックしたいなら、彼はパスワードを解読する方法を考え出すでしょう。 結論?あなたが絶対にあなたのコードを秘密にする必要があるのなら、Excelは開発プラットフォームのための最良の選択ではありません。
<! - 3 - >
コードを整理するアプリケーションが満足のいく結果を得たら、整理する必要があります。コードハウスキーピングタスクには、以下が含まれます。
すべての変数が宣言されていることを確認します。
-
すべての行が適切にインデントされてコード構造が明らかになるようにします。
-
デバッグのMsgBoxステートメントなどのデバッグ補助をすべて削除します。印刷ステートメント。
-
不適切な名前の変数の名前を変更します。たとえば、変数MyVariableを使用すると、変数名をより分かりやすくすることができます。あなたは後で自分自身に感謝するでしょう。
-
あなたのモジュールには、何かを把握しようとしているときに書いた、いくつかの「テスト」手順があるでしょう。彼らは目的を果たしたので、削除してください。
-
コメントを追加すると、6か月後にコードを再訪したときのコードの動作を理解できます。
-
すべての綴りが正しいこと、特にユーザーフォームとメッセージボックスのテキストが正しいことを確認します。
-
冗長コードを確認します。同じコードブロックを持つプロシージャが2つ以上ある場合は、他のプロシージャから呼び出せる新しいプロシージャを作成することを検討してください。
-
すべてのものを一つの手続きに入れない
分かりにくいプログラムを作りたいですか?それを達成するための効率的な方法は、あなたのコードをすばらしいひとつの大きな手順の中に置くことです。このプログラムをもう一度やり直して変更を加えたら、間違いを犯して細かいバグを導入する必要があります。
問題が見えますか?ソリューションはモジュール式のコードです。プログラムを小さなチャンクに分割し、それぞれのチャンクは特定のタスクを実行するように設計されています。この習慣を習得すると、バグのないコードを書くことがこれまで以上に簡単になることがわかります。
他のソフトウェアを検討する
Excelは驚くほど多彩なプログラムですが、すべてに適していません。新しいプロジェクトを開始する準備ができたら、時間をかけてすべてのオプションを検討してください。古い言葉を言い換えると、「あなたが知っていることはすべてExcel VBAだと、すべてがVBAマクロのように見えます。 "
誰もがマクロを有効にするとは仮定しない
知っているように、Excelではマクロを無効にしたブックを開くことができます。実際には、Excelの最新バージョンのデザイナーが
ユーザーにマクロを無効にしたいのとほぼ同じです。 不明なソースからブックを開くときにマクロを有効にすることは当然のことではありません。だからあなたはあなたのユーザーを知る必要があります。いくつかの企業環境では、すべてのMicrosoft Officeマクロが無効になっており、そのユーザーは選択肢がありません。 考慮すべき点の1つは、他の人に配布するワークブックにデジタル署名を追加することです。このようにして、ワークブックが実際にあなたから来たものであり、変更されていないことをユーザーに保証することができます。デジタル署名の詳細については、ヘルプシステムを参照してください。
実験の習慣に入るか?
単純な実験を設定することは、実験の内容を理解せずに既存のコードに新しいアイデアを組み込むよりもずっと効率的です。
あなたのコードが他のExcelバージョンで動作するとは思わない
現在、世界中で少なくとも5つのバージョンのExcelが一般的に使用されています。 Excelアプリケーションを作成するとき、それが古いバージョンまたは新しいバージョンで完全に機能するという保証は全くありません。場合によっては、非互換性が明らかになります。しかし、以前のバージョンで動作するはずのものが動作しないことも分かります。
Excelには便利な互換性チェッカーが含まれています(ファイル→情報→問題のチェック→互換性のチェックを選択します)が、ブックをチェックしてVBAコードを無視します。アプリケーションが作成したもの以外のバージョンで動作することを確認する唯一の方法は、それらのバージョンでテストすることです。
あなたのことを覚えておいてください
他の人のためにアプリケーションを開発する場合、自分で開発するときと同じ種類の仮定をすることはできないため、仕事はより困難です。
たとえば、あなたが唯一のユーザであれば、エラー処理でもっと甘くすることができます。エラーが発生した場合は、どこを見て修正することができるかを知ることができます。他の誰かがあなたのアプリを使用していて、同じエラーが表示された場合、彼または彼女は不運になります。また、自分のアプリケーションを使って作業しているときは、通常は指示なしに取得できます。
あなたは、あなたのワークブックを使用する人のスキルレベルを理解し、それが持つ可能性のある問題を予測しようとする必要があります。アプリケーションの新しいユーザーとして自分自身を描き、混乱や問題を引き起こす可能性のあるすべての領域を特定してください。
バックアップを忘れないでください
バックアップなしでハードドライブのクラッシュよりも落胆するものはありません。重要なプロジェクトに取り組んでいる場合は、簡単な質問をしてください。「今夜コンピュータが死んでしまったら、私は何を失うでしょうか?あなたの答えが数時間を超える場合は、データのバックアップ手順を詳しく見ていく必要があります。データのバックアップ手順はありますか?