目次:
ビデオ: 【初心者向けエクセルVBA】オブジェクトを変数にセットして取り扱う方法 2024
VBAコード内のオブジェクトを参照することは重要です結局のところ、VBAはあなたの心を読むことができません - まだ。読み物オブジェクトはExcel 2019で導入されることが噂されています。
オブジェクトのコレクション全体をひとつにして作業することができます。ただし、コレクション内の特定のオブジェクト(ワークブック内の特定のワークシートなど)で作業する必要があることがよくあります。コレクションから1つのオブジェクトを参照するには、コレクションの名前の後のカッコ内にオブジェクトの名前またはインデックス番号を入れます(
<! - 1 - >ワークシート( "Sheet1")
シートの名前は引用符で囲まれています。引用符を省略すると、Excelはオブジェクトを識別することができなくなります(変数名であるとみなされます)。
Sheet1がコレクション内の最初の(または唯一の)ワークシートの場合、次の参照を使用することもできます。
ワークシート(1)
この場合、数値は ではなく 引用符。結論?名前を使用してオブジェクトを参照する場合は、引用符を使用します。インデックス番号を使用してオブジェクトを参照する場合は、引用符のないプレーン番号を使用します。
<! - 2 - >チャートシートはどうですか?チャートシートには単一のチャートが含まれています。シートタブがありますが、ワークシートではありません。さて、オブジェクトモデルにはChartsというコレクションがあります。このコレクションには、ブック内のすべてのチャートシートオブジェクトが含まれます(ワークシートに埋め込まれたチャートは含まれません)。
そして物事を論理的に保つために、Sheetsという別のコレクションがあります。 Sheetsコレクションには、ワークブック内のすべてのシート(ワークシートとチャートシート)が含まれます。 Sheetsコレクションは、ワークブック内のすべてのシートを処理し、ワークシートまたはチャートシートの場合は気にしない場合に便利です。
<! - 3 - >したがって、Sheet1という単一のワークシートは、WorksheetsコレクションとSheetsコレクションの2つのコレクションのメンバーです。
ワークシート( "シート1")シート( "シート1")
階層をナビゲートする
Excelオブジェクトを使用する場合は、すべてが下にありますアプリケーションオブジェクト。まず、 Application と入力します。
Excelのオブジェクトモデル内の他のすべてのオブジェクトは、Applicationオブジェクトの下にあります。これらのオブジェクトに到達するには、階層を下に移動し、途中で各オブジェクトをドット(。)演算子で接続します。 Book1という名前のWorkbookオブジェクトに到達するには。 xlsx、Applicationオブジェクトから始め、Workbooksコレクションオブジェクト
Applicationに移動します。ワークブック( "Book1。xlsx")
特定のワークシートにさらに移動するには、ドット演算子を追加し、
Application:Worksheetsコレクションオブジェクトにアクセスします。ブック( "Book1。xlsx")。ワークシート(1)
まだ十分ではありませんか? Book1という名前のブックの最初のワークシートのA1セルから値を取得する場合は、 xlsxを使用する場合は、さらに1つのレベルをRangeオブジェクトに移動する必要があります。
Application。ブック( "Book1。xlsx")。ワークシート(1)。範囲( "A1")。 Value
このようにRangeオブジェクトを参照すると、それは 完全修飾参照と呼ばれます。 あなたは、どの範囲のワークシートやワークブックを望むのかをExcelに正確に伝え、想像力に何も残さなかった。想像力は人には良いが、コンピュータプログラムではそれほど良くない。
ところで、ブック名には、拡張子からファイル名を区切るためのドットもあります(たとえば、Book1。xlsx)。それはちょうど偶然のことです。ファイル名のドットは、ドット演算子とはまったく関係がありません。
オブジェクト参照の単純化
オブジェクト参照をすべて修飾する必要がある場合は、コードがかなり長くなり、読みにくくなる可能性があります。幸いにも、Excelには、読みやすさを向上させるためのいくつかのショートカットが用意されています。まず、Applicationオブジェクトが常に想定されます。入力するのが理にかなっているケースはごくわずかです。 Applicationオブジェクトリファレンスを省略すると、この例は
Workbooks( "Book1。xlsx")に短縮されます。ワークシート(1)。範囲( "A1")。値
それはかなり良い改善です。しかし、待って、もっと多くのことがあります。もしあなたが確かにBook1。 xlsxはアクティブなワークブックですが、その参照も省略できます。今度は
ワークシート(1)になります。範囲( "A1")。値
今どこかに行っています。あなたは次のショートカットを推測しましたか?そのとおり。最初のワークシートが現在アクティブなワークシートであることがわかっている場合、Excelはその参照を想定して、
Range( "A1")と入力するだけです。値
一部の人々が考えるとは対照的に、ExcelにはCellオブジェクトがありません。 セル は単なる1つの要素で構成されるRangeオブジェクトです。
ここに記載されているショートカットは素晴らしいものですが、危険なこともあります。あなたが Book1だけを考えるとどうなるでしょうか? xlsxはアクティブなワークブックですか?あなたは間違いをすることができますか、悪いことに、間違った価値を得ることができ、それが間違っていることさえも認識しません。そのため、オブジェクト参照を完全修飾することが最善の方法です。 With-End With構造は、参照を完全修飾するのに役立ちますが、コードをより読みやすくし、型を削減します。両方の世界の最高!