VBA-クイックガイド

VBAは Visual Basic for Aアプリケーションは、現在主にMSExcel、MS-Word、MS-AccessなどのMicrosoftOfficeアプリケーションで使用されているMicrosoftのイベント駆動型プログラミング言語です。

これは、技術者がカスタマイズされたアプリケーションとソリューションを構築して、それらのアプリケーションの機能を強化するのに役立ちます。この機能の利点は、PCにVisual Basicをインストールする必要がないことですが、Officeをインストールすると、目的を達成するのに暗黙的に役立ちます。

VBAは、MS-Office97からMS-Office2013まで、および利用可能な最新バージョンのいずれかを使用して、すべてのOfficeバージョンで使用できます。VBAの中で、ExcelVBAが最も人気があります。VBAを使用する利点は、線形計画法を使用してMSExcelで非常に強力なツールを構築できることです。

VBAの適用

MS-Excel自体が多数の組み込み関数を提供するため、ExcelでVBAを使用する理由を疑問に思うかもしれません。MS-Excelは、複雑な計算を実行するには不十分な基本的な組み込み関数のみを提供します。このような状況では、VBAが最も明白なソリューションになります。

たとえば、Excelの組み込み式を使用してローンの毎月の返済額を計算することは非常に困難です。むしろ、そのような計算のためにVBAをプログラムするのは簡単です。

VBAエディターへのアクセス

Excelウィンドウで、「ALT + F11」を押します。次のスクリーンショットに示すように、VBAウィンドウが開きます。

この章では、簡単なマクロを段階的に作成する方法を学習します。

Step 1−まず、Excel20XXで「開発者」メニューを有効にします。同じことを行うには、[ファイル]→[オプション]をクリックします。

Step 2− [リボンのカスタマイズ]タブをクリックし、[開発者]をオンにします。[OK]をクリックします。

Step 3 −メニューバーに「開発者」リボンが表示されます。

Step 4 −「VisualBasic」ボタンをクリックしてVBAエディタを開きます。

Step 5−ボタンを追加してスクリプトを開始します。[挿入]→[ボタンを選択]をクリックします。

Step 6 −右クリックして、「プロパティ」を選択します。

Step 7 −次のスクリーンショットに示すように、名前とキャプションを編集します。

Step 8 −ボタンをダブルクリックすると、次のスクリーンショットに示すように、サブプロシージャの概要が表示されます。

Step 9 −メッセージを追加するだけでコーディングを開始できます。

Private Sub say_helloworld_Click()
   MsgBox "Hi"
End Sub

Step 10−ボタンをクリックして、サブプロシージャを実行します。サブプロシージャの出力を次のスクリーンショットに示します。デザインモードがオンになっていることを確認してください。オンになっていない場合は、クリックするだけでオンになります。

Note −以降の章では、ステップ1から10で説明したように、簡単なボタンの使用方法を示します。したがって、この章を完全に理解することが重要です。

この章では、一般的に使用されるExcelVBAの用語について説明します。これらの用語は以降のモジュールで使用されるため、これらの各用語を理解することが重要です。

モジュール

モジュールは、コードが記述される領域です。これは新しいワークブックであるため、モジュールはありません。

モジュールを挿入するには、[挿入]→[モジュール]に移動します。モジュールが挿入されると、「module1」が作成されます。

モジュール内でVBAコードを記述でき、コードはプロシージャ内で記述されます。プロシージャ/サブプロシージャは、何をすべきかを指示する一連のVBAステートメントです。

手順

プロシージャは、全体として実行されるステートメントのグループであり、特定のタスクを実行する方法をExcelに指示します。実行されるタスクは、非常に単純なタスクでも、非常に複雑なタスクでもかまいません。ただし、複雑な手順をより小さな手順に分割することをお勧めします。

プロシージャの2つの主なタイプは、サブと関数です。

関数

関数は再利用可能なコードのグループであり、プログラムのどこからでも呼び出すことができます。これにより、同じコードを何度も書く必要がなくなります。これは、プログラマーが大きなプログラムをいくつかの小さくて管理しやすい関数に分割するのに役立ちます。

組み込み関数とは別に、VBAではユーザー定義関数も記述でき、ステートメントは Function そして End Function

サブ手順

サブプロシージャは関数と同様に機能します。サブプロシージャは値を返しませんが、関数は値を返す場合と返さない場合があります。サブプロシージャは、callキーワードなしで呼び出すことができます。サブプロシージャは常に次のように囲まれていますSub そして End Sub ステートメント。

コメントは、プログラムロジックと、他のプログラマーが将来同じコードでシームレスに作業できるユーザー情報を文書化するために使用されます。

これには、によって開発、変更されたなどの情報が含まれ、組み込まれたロジックを含めることもできます。コメントは、実行中にインタプリタによって無視されます。

VBAのコメントは、2つの方法で示されます。

  • 一重引用符( ')で始まるステートメントは、コメントとして扱われます。以下は例です。

' This Script is invoked after successful login 
' Written by : TutorialsPoint 
' Return Value : True / False
  • キーワード「REM」で始まるステートメント。以下は例です。

REM This Script is written to Validate the Entered Input 
REM Modified by  : Tutorials point/user2

ザ・ MsgBox function メッセージボックスを表示し、ユーザーがボタンをクリックするのを待ってから、ユーザーがクリックしたボタンに基づいてアクションが実行されます。

構文

MsgBox(prompt[,buttons][,title][,helpfile,context])

パラメータの説明

  • Prompt−必須パラメーター。ダイアログボックスにメッセージとして表示される文字列。プロンプトの最大長は約1024文字です。メッセージが1行を超えている場合は、各行の間に改行文字(Chr(13))または改行文字(Chr(10))を使用して行を区切ることができます。

  • Buttons−オプションのパラメータ。表示するボタンのタイプ、使用するアイコンスタイル、デフォルトボタンのID、およびメッセージボックスのモダリティを指定する数式。空白のままにすると、ボタンのデフォルト値は0になります。

  • Title−オプションのパラメータ。ダイアログボックスのタイトルバーに表示される文字列式。タイトルを空白のままにすると、アプリケーション名がタイトルバーに表示されます。

  • Helpfile−オプションのパラメータ。ダイアログボックスの状況依存ヘルプを提供するために使用するヘルプファイルを識別する文字列式。

  • Context−オプションのパラメータ。ヘルプ作成者によって適切なヘルプトピックに割り当てられたヘルプコンテキスト番号を識別する数式。コンテキストを指定する場合は、ヘルプファイルも指定する必要があります。

ザ・ Buttons パラメータは次の値のいずれかを取ることができます-

  • 0vbOKOnly- [OK]ボタンのみを表示します。

  • 1vbOKCancel- [OK]ボタンと[キャンセル]ボタンを表示します。

  • 2 vbAbortRetryIgnore- [中止]、[再試行]、および[無視]ボタンを表示します。

  • 3 vbYesNoCancel- [はい]、[いいえ]、および[キャンセル]ボタンを表示します。

  • 4vbYesNo- [はい]ボタンと[いいえ]ボタンを表示します。

  • 5vbRetryCancel-再試行ボタンとキャンセルボタンを表示します。

  • 16vbCritical-クリティカルメッセージアイコンを表示します。

  • 32vbQuestion-警告クエリアイコンを表示します。

  • 48vbExclamation-警告メッセージアイコンを表示します。

  • 64vbInformation-情報メッセージアイコンを表示します。

  • 0vbDefaultButton1-最初のボタンがデフォルトです。

  • 256vbDefaultButton2-2番目のボタンがデフォルトです。

  • 512vbDefaultButton3-3番目のボタンがデフォルトです。

  • 768vbDefaultButton4-4番目のボタンがデフォルトです。

  • 0 vbApplicationModalアプリケーションモーダル-現在のアプリケーションは、ユーザーがメッセージボックスに応答するまで機能しません。

  • 4096 vbSystemModalシステムモーダル-ユーザーがメッセージボックスに応答するまで、すべてのアプリケーションは機能しません。

上記の値は、論理的に4つのグループに分けられます。 first group(0〜5)は、メッセージボックスに表示するボタンを示します。ザ・second group (16、32、48、64)は、表示されるアイコンのスタイルを示します。 third group (0、256、512、768)は、どのボタンをデフォルトにする必要があるかを示し、 fourth group (0、4096)は、メッセージボックスのモダリティを決定します。

戻り値

MsgBox関数は、ユーザーがメッセージボックスでクリックしたボタンを識別するために使用できる次の値のいずれかを返すことができます。

  • 1-vbOK- [OK]をクリックしました
  • 2-vbCancel-キャンセルがクリックされました
  • 3-vbAbort-中止がクリックされました
  • 4-vbRetry-再試行がクリックされました
  • 5-vbIgnore-無視がクリックされました
  • 6-vbYes-はいがクリックされました
  • 7-vbNo-クリックされませんでした

Function MessageBox_Demo() 
   'Message Box with just prompt message 
   MsgBox("Welcome")     
   
   'Message Box with title, yes no and cancel Butttons  
   int a = MsgBox("Do you like blue color?",3,"Choose options") 
   ' Assume that you press No Button  
   msgbox ("The Value of a is " & a) 
End Function

出力

Step 1 −上記の関数は、VBAウィンドウの[実行]ボタンをクリックするか、次のスクリーンショットに示すようにExcelワークシートから関数を呼び出すことで実行できます。

Step 2 −シンプルメッセージボックスが表示され、「ようこそ」と「OK」ボタンが表示されます。

Step 3 − [OK]をクリックすると、さらに別のダイアログボックスが表示され、「はい、いいえ、キャンセル」ボタンとともにメッセージが表示されます。

Step 4− [いいえ]ボタンをクリックすると、そのボタン(7)の値が整数として保存され、次のスクリーンショットに示すようにユーザーにメッセージボックスとして表示されます。この値を使用すると、ユーザーがどのボタンをクリックしたかを理解できます。

ザ・ InputBox functionユーザーに値の入力を求めます。値を入力した後、ユーザーが[OK]ボタンをクリックするか、キーボードのEnterキーを押すと、InputBox関数はテキストボックスにテキストを返します。ユーザーが[キャンセル]ボタンをクリックすると、関数は空の文字列( "")を返します。

構文

InputBox(prompt[,title][,default][,xpos][,ypos][,helpfile,context])

パラメータの説明

  • Prompt−必須パラメーター。ダイアログボックスにメッセージとして表示される文字列。プロンプトの最大長は約1024文字です。メッセージが1行を超えている場合は、各行の間に改行文字(Chr(13))または改行文字(Chr(10))を使用して行を区切ることができます。

  • Title−オプションのパラメータ。ダイアログボックスのタイトルバーに表示される文字列式。タイトルを空白のままにすると、アプリケーション名がタイトルバーに表示されます。

  • Default−オプションのパラメータ。ユーザーが表示したいテキストボックスのデフォルトテキスト。

  • XPos−オプションのパラメータ。の位置X軸は、画面の左側から水平方向のプロンプト距離を表します。空白のままにすると、入力ボックスは水平方向の中央に配置されます。

  • YPos−オプションのパラメータ。の位置Y軸は、画面の左側から垂直方向のプロンプト距離を表します。空白のままにすると、入力ボックスは垂直方向の中央に配置されます。

  • Helpfile−オプションのパラメータ。ダイアログボックスの状況依存ヘルプを提供するために使用されるヘルプファイルを識別する文字列式。

  • context−オプションのパラメータ。ヘルプ作成者によって適切なヘルプトピックに割り当てられたヘルプコンテキスト番号を識別する数式。コンテキストを指定する場合は、ヘルプファイルも指定する必要があります。

2つの入力ボックス(1つは長さ用、もう1つは幅用)を使用して実行時にユーザーから値を取得することにより、長方形の面積を計算してみましょう。

Function findArea() 
   Dim Length As Double 
   Dim Width As Double 
   
   Length = InputBox("Enter Length ", "Enter a Number") 
   Width = InputBox("Enter Width", "Enter a Number") 
   findArea = Length * Width 
End Function

出力

Step 1 −同じことを実行するには、次のスクリーンショットに示すように、関数名を使用して呼び出し、Enterキーを押します。

Step 2−実行すると、最初の入力ボックス(長さ)が表示されます。入力ボックスに値を入力します。

Step 3 −最初の値を入力すると、2番目の入力ボックス(幅)が表示されます。

Step 4− 2番目の番号を入力したら、[OK]ボタンをクリックします。次のスクリーンショットに示すように、領域が表示されます。

Variableスクリプトの実行中に変更できる値を保持するために使用される名前付きメモリの場所です。変数に名前を付けるための基本的なルールは次のとおりです。

  • 最初の文字として文字を使用する必要があります。

  • 名前にスペース、ピリオド(。)、感嘆符(!)、または文字@、&、$、#を使用することはできません。

  • 名前の長さは255文字を超えることはできません。

  • VisualBasicの予約済みキーワードを変数名として使用することはできません。

Syntax

VBAでは、変数を使用する前に変数を宣言する必要があります。

Dim <<variable_name>> As <<variable_type>>

データ型

多くのVBAデータ型があり、数値データ型と非数値データ型の2つの主要なカテゴリに分類できます。

数値データ型

次の表に、数値データ型と許容値の範囲を示します。

タイプ 値の範囲
バイト 0から255
整数 -32,768〜32,767
長いです -2,147,483,648から2,147,483,648
シングル

-3.402823E + 38〜-1.401298E-45(負の値の場合)

正の値の場合は1.401298E-45から3.402823E + 38。

ダブル

-1.79769313486232e + 308〜-4.94065645841247E-324(負の値の場合)

正の値の場合は4.94065645841247E-324から1.77969313486232e + 308。

通貨 -922,337,203,685,477.5808から922,337,203,685,477.5807
10進数

小数を使用しない場合は+/- 79,228,162,514,264,337,593,543,950,335

+/- 7.9228162514264337593543950335(小数点以下28桁)。

非数値データ型

次の表は、数値以外のデータ型と許容される値の範囲を示しています。

タイプ 値の範囲
文字列(固定長) 1〜65,400文字
文字列(可変長) 0〜20億文字
日付 100年1月1日から9999年12月31日
ブール値 正しいか間違っているか
オブジェクト 埋め込まれたオブジェクト
バリアント(数値) 2倍の値
バリアント(テキスト) 可変長文字列と同じ

Example

ボタンを作成し、「Variables_demo」という名前を付けて、変数の使用法を示しましょう。

Private Sub say_helloworld_Click()
   Dim password As String
   password = "Admin#1"

   Dim num As Integer
   num = 1234

   Dim BirthDay As Date
   BirthDay = DateValue("30 / 10 / 2020")

   MsgBox "Passowrd is " & password & Chr(10) & "Value of num is " &
      num & Chr(10) & "Value of Birthday is " & BirthDay
End Sub

Output

スクリプトを実行すると、出力は次のスクリーンショットのようになります。

定数は、スクリプトの実行中に変更できない値を保持するために使用される名前付きメモリの場所です。ユーザーが定数値を変更しようとすると、スクリプトの実行でエラーが発生します。定数は、変数が宣言されるのと同じ方法で宣言されます。

定数に名前を付けるための規則は次のとおりです。

  • 最初の文字として文字を使用する必要があります。

  • 名前にスペース、ピリオド(。)、感嘆符(!)、または文字@、&、$、#を使用することはできません。

  • 名前の長さは255文字を超えることはできません。

  • VisualBasicの予約済みキーワードを変数名として使用することはできません。

構文

VBAでは、宣言された定数に値を割り当てる必要があります。定数の値を変更しようとすると、エラーがスローされます。

Const <<constant_name>> As <<constant_type>> = <<constant_value>>

定数の操作方法を示すボタン「Constant_demo」を作成しましょう。

Private Sub Constant_demo_Click() 
   Const MyInteger As Integer = 42 
   Const myDate As Date = #2/2/2020# 
   Const myDay As String = "Sunday" 
   
   MsgBox "Integer is " & MyInteger & Chr(10) & "myDate is " 
      & myDate & Chr(10) & "myDay is " & myDay  
End Sub

出力

スクリプトを実行すると、次のスクリーンショットに示すように出力が表示されます。

アン Operator 簡単な式を使用して定義できます-4+ 5は9に等しいここで、4と5は呼び出されます operands そして+は呼ばれます operator。VBAは次のタイプの演算子をサポートします-

  • 算術演算子
  • 比較演算子
  • 論理(または関係)演算子
  • 連結演算子

算術演算子

次の算術演算子はVBAでサポートされています。

変数Aが5を保持し、変数Bが10を保持すると仮定すると、-

例を表示

オペレーター 説明
+ 2つのオペランドを追加します A + Bは15を与えます
- 最初のオペランドから2番目のオペランドを減算します A-Bは-5を与えます
* 両方のオペランドを乗算します A * Bは50を与えます
/ 分子を分母で割ります B / Aは2を与えます
モジュラス演算子と整数除算後の余り B%Aは0を与えます
^ べき乗演算子 B ^ Aは100000を与えます

比較演算子

VBAでサポートされている比較演算子は次のとおりです。

変数Aが10を保持し、変数Bが20を保持すると仮定すると、-

例を表示

オペレーター 説明
= 2つのオペランドの値が等しいかどうかを確認します。はいの場合、条件は真です。 (A = B)はFalseです。
<> 2つのオペランドの値が等しいかどうかを確認します。値が等しくない場合、条件は真です。 (A <> B)は真です。
>> 左のオペランドの値が右のオペランドの値より大きいかどうかを確認します。はいの場合、条件は真です。 (A> B)はFalseです。
< 左のオペランドの値が右のオペランドの値よりも小さいかどうかを確認します。はいの場合、条件は真です。 (A <B)は真です。
> = 左のオペランドの値が右のオペランドの値以上であるかどうかを確認します。はいの場合、条件は真です。 (A> = B)はFalseです。
<= 左のオペランドの値が右のオペランドの値以下であるかどうかを確認します。はいの場合、条件は真です。 (A <= B)は真です。

論理演算子

次の論理演算子はVBAでサポートされています。

変数Aが10を保持し、変数Bが0を保持すると仮定すると、-

例を表示

オペレーター 説明
そして 論理AND演算子と呼ばれます。両方の条件が真の場合、式は真です。 a <> 0 AND b <> 0はFalseです。
または 論理OR演算子と呼ばれます。2つの条件のいずれかが真の場合、条件は真です。 a <> 0またはb <> 0が真です。
ない 論理NOT演算子と呼ばれます。オペランドの論理状態を逆にするために使用されます。条件がtrueの場合、LogicalNOT演算子はfalseになります。 NOT(a <> 0 OR b <> 0)はfalseです。
XOR 論理的除外と呼ばれます。これは、NOT演算子とOR演算子の組み合わせです。式の1つだけがTrueであると評価された場合、結果はTrueになります。 (a <> 0 XOR b <> 0)は真です。

連結演算子

次の連結演算子はVBAでサポートされています。

変数Aが5を保持し、変数Bが10を保持すると仮定すると、-

例を表示

オペレーター 説明
+ 変数として2つの値を追加します。値は数値です A + Bは15を与えます
2つの値を連結します A&Bは510を与えます

変数A = "Microsoft"および変数B = "VBScript"と仮定すると、-

オペレーター 説明
+ 2つの値を連結します A + BはMicrosoftVBScriptを提供します
2つの値を連結します A&BはMicrosoftVBScriptを提供します

Note−連結演算子は、数値と文字列の両方に使用できます。変数が数値または文字列値を保持する場合、出力はコンテキストによって異なります。

意思決定により、プログラマーはスクリプトまたはそのセクションの1つの実行フローを制御できます。実行は、1つ以上の条件ステートメントによって制御されます。

以下は、ほとんどのプログラミング言語に見られる典型的な意思決定構造の一般的な形式です。

VBAは、次のタイプの意思決定ステートメントを提供します。詳細を確認するには、次のリンクをクリックしてください。

シニア番号 ステートメントと説明
1 ifステートメント

アン if ステートメントは、ブール式とそれに続く1つ以上のステートメントで構成されます。

2 if..elseステートメント

アン if elseステートメントは、ブール式とそれに続く1つ以上のステートメントで構成されます。条件がTrueの場合、以下のステートメントIfステートメントが実行されます。条件が偽の場合、Else スクリプトの一部が実行されます。

3 if ... elseif..elseステートメント

アン if ステートメントの後に1つ以上が続く ElseIf ブール式で構成され、その後にオプションのステートメントが続くステートメント else statement、すべての条件がfalseになったときに実行されます。

4 ネストされたifステートメント

アン if または elseif 別の内部のステートメント if または elseif ステートメント。

5 switchステートメント

A switch ステートメントを使用すると、値のリストに対して変数が等しいかどうかをテストできます。

コードのブロックを数回実行する必要がある場合があります。一般に、ステートメントは順番に実行されます。関数の最初のステートメントが最初に実行され、次に2番目のステートメントが実行されます。

プログラミング言語は、より複雑な実行パスを可能にするさまざまな制御構造を提供します。

ループステートメントを使用すると、ステートメントまたはステートメントのグループを複数回実行できます。以下は、VBAでのループステートメントの一般的な形式です。

VBAは、ループ要件を処理するために次のタイプのループを提供します。詳細を確認するには、次のリンクをクリックしてください。

シニア番号 ループの種類と説明
1 forループ

一連のステートメントを複数回実行し、ループ変数を管理するコードを省略します。

2 for ..各ループ

これは、グループ内に少なくとも1つの要素があり、グループ内の要素ごとに繰り返される場合に実行されます。

3 while..wendループ

これは、ループ本体を実行する前に条件をテストします。

4 do..whileループ

do..Whileステートメントは、条件がTrueである限り実行されます。(つまり)条件がFalseになるまでループを繰り返す必要があります。

5 do ..ループまで

条件がFalseである限り、do..Untilステートメントが実行されます。(つまり)条件がTrueになるまでループを繰り返す必要があります。

ループ制御ステートメント

ループ制御ステートメントは、実行を通常のシーケンスから変更します。実行がスコープを離れると、ループ内の残りのすべてのステートメントは実行されません。

VBAは、次の制御ステートメントをサポートしています。詳細を確認するには、次のリンクをクリックしてください。

S.No. 制御ステートメントと説明
1 ステートメントの終了

を終了します For loop ステートメントを実行し、ループの直後のステートメントに実行を転送します

2 Doステートメントの終了

を終了します Do While ステートメントを実行し、ループの直後のステートメントに実行を転送します

文字列は文字のシーケンスであり、アルファベット、数字、特殊文字、またはそれらすべてで構成できます。変数が二重引用符 ""で囲まれている場合、その変数は文字列であると言われます。

構文

variablename = "string"

str1 = "string"   ' Only Alphabets
str2 = "132.45"   ' Only Numbers
str3 = "!@#$;*"  ' Only Special Characters
Str4 = "Asc23@#"  ' Has all the above

文字列関数

事前定義されたVBA文字列関数があり、開発者が文字列を非常に効果的に操作するのに役立ちます。以下は、VBAでサポートされている文字列メソッドです。詳細については、それぞれの方法をクリックしてください。

シニア番号 関数名と説明
1 InStr

指定された部分文字列の最初の出現を返します。検索は左から右に行われます。

2 InstrRev

指定された部分文字列の最初の出現を返します。検索は右から左に行われます。

3 Lcase

指定された文字列の小文字を返します。

4 Ucase

指定された文字列の大文字を返します。

5

文字列の左側から特定の文字数を返します。

6 正しい

文字列の右側から特定の文字数を返します。

7 ミッド

指定されたパラメータに基づいて、文字列から特定の文字数を返します。

8 Ltrim

指定された文字列の左側のスペースを削除した後、文字列を返します。

9 Rtrim

指定された文字列の右側のスペースを削除した後、文字列を返します。

10 トリム

先頭と末尾の両方の空白スペースを削除した後、文字列値を返します。

11 レン

指定された文字列の長さを返します。

12 交換

文字列を別の文字列に置き換えた後、文字列を返します。

13 スペース

指定された数のスペースで文字列を埋めます。

14 StrComp

指定された2つの文字列を比較した後、整数値を返します。

15 ストリング

指定された回数、指定された文字の文字列を返します。

16 StrReverse

指定された文字列の文字の順序を逆にした後、文字列を返します。

VBScriptの日付と時刻の関数は、開発者が日付と時刻をある形式から別の形式に変換したり、特定の条件に適した形式で日付または時刻の値を表現したりするのに役立ちます。

日付関数

シニア番号 機能と説明
1 日付

現在のシステム日付を返す関数。

2 CDate

指定された入力を日付に変換する関数。

3 DateAdd

指定された時間間隔が追加された日付を返す関数。

4 DateDiff

2つの期間の差を返す関数。

5 DatePart

指定された入力日付値の指定された部分を返す関数。

6 DateSerial

指定された年、月、および日付の有効な日付を返す関数。

7 FormatDateTime

指定されたパラメーターに基づいて日付をフォーマットする関数。

8 IsDate

指定されたパラメーターが日付であるかどうかに関係なくブール値を返す関数。

9

指定された日付の日を表す1から31までの整数を返す関数。

10

指定された日付の月を表す1から12までの整数を返す関数。

11

指定された日付の年を表す整数を返す関数。

12 MonthName

指定された日付の特定の月の名前を返す関数。

13 平日

指定された日の曜日を表す整数(1から7)を返す関数。

14 WeekDayName

指定された日の平日の名前を返す関数。

時間関数

シニア番号 機能と説明
1

現在のシステムの日付と時刻を返す関数。

2 時間

指定された時間の時間部分を表す0から23までの整数を返す関数。

3

指定された時間の分部分を表す0から59までの整数を返す関数。

4 2番目

指定された時間の秒部分を表す0から59までの整数を返す関数。

5 時間

現在のシステム時刻を返す関数。

6 タイマー

午前12:00からの秒数とミリ秒数を返す関数。

7 TimeSerial

時間、分、秒の特定の入力の時間を返す関数。

8 TimeValue

入力文字列を時間形式に変換する関数。

変数が値を格納するためのコンテナーであることはよく知っています。開発者は、一度に1つの変数に複数の値を保持できる場合があります。一連の値が単一の変数に格納されている場合、それはarray variable

配列宣言

配列は、配列変数の宣言が括弧を使用することを除いて、変数が宣言されたのと同じ方法で宣言されます。次の例では、配列のサイズが括弧内に示されています。

'Method 1 : Using Dim
Dim arr1()	'Without Size

'Method 2 : Mentioning the Size
Dim arr2(5)  'Declared with size of 5

'Method 3 : using 'Array' Parameter
Dim arr3
arr3 = Array("apple","Orange","Grapes")
  • 配列サイズは5と示されていますが、配列インデックスはZEROから始まるため、6つの値を保持できます。

  • 配列インデックスを負にすることはできません。

  • VBScript配列は、任意のタイプの変数を配列に格納できます。したがって、配列は整数、文字列、または文字を単一の配列変数に格納できます。

配列への値の割り当て

値は、割り当てられる値のそれぞれに対して配列インデックス値を指定することによって配列に割り当てられます。文字列にすることができます。

ボタンを追加し、以下の機能を追加します。

Private Sub Constant_demo_Click()
   Dim arr(5)
   arr(0) = "1"           'Number as String
   arr(1) = "VBScript"    'String
   arr(2) = 100 		     'Number
   arr(3) = 2.45 		     'Decimal Number
   arr(4) = #10/07/2013#  'Date
   arr(5) = #12.45 PM#    'Time
  
   msgbox("Value stored in Array index 0 : " & arr(0))
   msgbox("Value stored in Array index 1 : " & arr(1))
   msgbox("Value stored in Array index 2 : " & arr(2))
   msgbox("Value stored in Array index 3 : " & arr(3))
   msgbox("Value stored in Array index 4 : " & arr(4))
   msgbox("Value stored in Array index 5 : " & arr(5))
End Sub

上記の関数を実行すると、次の出力が生成されます。

Value stored in Array index 0 : 1
Value stored in Array index 1 : VBScript
Value stored in Array index 2 : 100
Value stored in Array index 3 : 2.45
Value stored in Array index 4 : 7/10/2013
Value stored in Array index 5 : 12:45:00 PM

多次元配列

配列は単一の次元に限定されるだけでなく、最大60の次元を持つことができます。2次元配列は、最も一般的に使用される配列です。

次の例では、多次元配列が3行4列で宣言されています。

Private Sub Constant_demo_Click()
   Dim arr(2,3) as Variant	' Which has 3 rows and 4 columns
   arr(0,0) = "Apple" 
   arr(0,1) = "Orange"
   arr(0,2) = "Grapes"           
   arr(0,3) = "pineapple" 
   arr(1,0) = "cucumber"           
   arr(1,1) = "beans"           
   arr(1,2) = "carrot"           
   arr(1,3) = "tomato"           
   arr(2,0) = "potato"             
   arr(2,1) = "sandwitch"            
   arr(2,2) = "coffee"             
   arr(2,3) = "nuts"            
           
   msgbox("Value in Array index 0,1 : " &  arr(0,1))
   msgbox("Value in Array index 2,2 : " &  arr(2,2))
End Sub

上記の関数を実行すると、次の出力が生成されます。

Value stored in Array index : 0 , 1 : Orange
Value stored in Array index : 2 , 2 : coffee

ReDimステートメント

ReDimステートメントは、動的配列変数を宣言し、ストレージスペースを割り当てまたは再割り当てするために使用されます。

構文

ReDim [Preserve] varname(subscripts) [, varname(subscripts)]

パラメータの説明

  • Preserve −最後の次元のサイズを変更するときに、既存の配列のデータを保持するために使用されるオプションのパラメーター。

  • Varname −変数の名前を示す必須パラメーター。これは、標準の変数命名規則に従う必要があります。

  • Subscripts −配列のサイズを示す必須パラメーター。

次の例では、配列が再定義されており、配列の既存のサイズが変更されたときに値が保持されています。

Note −元の配列よりも小さい配列のサイズを変更すると、削除された要素のデータは失われます。

Private Sub Constant_demo_Click()
   Dim a() as variant
   i = 0
   redim a(5)
   a(0) = "XYZ"
   a(1) = 41.25
   a(2) = 22
  
   REDIM PRESERVE a(7)
   For i = 3 to 7
   a(i) = i
   Next
  
   'to Fetch the output
   For i = 0 to ubound(a)
      Msgbox a(i)
   Next
End Sub

上記の関数を実行すると、次の出力が生成されます。

XYZ
41.25
22
3
4
5
6
7

配列メソッド

VBScriptには、開発者が配列を効果的に処理するのに役立つさまざまな組み込み関数があります。配列と組み合わせて使用​​されるすべてのメソッドを以下に示します。詳細については、メソッド名をクリックしてください。

シニア番号 機能と説明
1 LBound

指定された配列の最小の添え字に対応する整数を返す関数。

2 UBound

指定された配列の最大の添え字に対応する整数を返す関数。

3 スプリット

指定された数の値を含む配列を返す関数。区切り文字に基づいて分割します。

4 参加する

配列内の指定された数の部分文字列を含む文字列を返す関数。これは、分割メソッドの正反対の関数です。

5 フィルタ

特定のフィルター基準に基づいて文字列配列のサブセットを含むゼロベースの配列を返す関数。

6 IsArray

入力変数が配列であるかどうかを示すブール値を返す関数。

7 消去

配列変数に割り当てられたメモリを回復する関数。

A functionプログラム内のどこからでも呼び出すことができる再利用可能なコードのグループです。これにより、同じコードを何度も書く必要がなくなります。これにより、プログラマーは大きなプログラムをいくつかの小さくて管理しやすい関数に分割することができます。

組み込み関数とは別に、VBAではユーザー定義関数を作成することもできます。この章では、VBAで独自の関数を作成する方法を学習します。

関数定義

VBA関数には、オプションのreturnステートメントを含めることができます。これは、関数から値を返したい場合に必要です。

たとえば、関数で2つの数値を渡すと、呼び出し元のプログラムで関数からそれらの乗算が返されることが期待できます。

Note −関数は、関数名自体に割り当てられた配列として、コンマで区切られた複数の値を返すことができます。

関数を使用する前に、その特定の関数を定義する必要があります。VBAで関数を定義する最も一般的な方法は、Function キーワードの後に​​一意の関数名が続き、パラメータのリストと次のステートメントが含まれる場合と含まれない場合があります。 End Function関数の終了を示すキーワード。以下は基本的な構文です。

構文

ボタンを追加し、以下の機能を追加します。

Function Functionname(parameter-list)
   statement 1
   statement 2
   statement 3
   .......
   statement n
End Function

面積を返す次の関数を追加します。関数名自体で1つまたは複数の値を返すことができることに注意してください。

Function findArea(Length As Double, Optional Width As Variant)
   If IsMissing(Width) Then
      findArea = Length * Length
   Else
      findArea = Length * Width
   End If
End Function

関数の呼び出し

関数を呼び出すには、次のスクリーンショットに示すように、関数名を使用して関数を呼び出します。

以下に示す領域の出力がユーザーに表示されます。

Sub Procedures 関数に似ていますが、いくつかの違いがあります。

  • 関数が値を返す場合と返さない場合がある間、サブプロシージャは値を返しません。

  • サブプロシージャは、callキーワードなしで呼び出すことができます。

  • Subプロシージャは、常にSubステートメントとEndSubステートメントで囲まれています。

Sub Area(x As Double, y As Double)
   MsgBox x * y
End Sub

呼び出し手順

スクリプトのどこかでプロシージャを呼び出すには、関数から呼び出しを行うことができます。サブプロシージャは値を返さないため、関数と同じ方法で使用することはできません。

Function findArea(Length As Double, Width As Variant)
   area Length, Width    ' To Calculate Area 'area' sub proc is called
End Function

これで、次のスクリーンショットに示すように、関数のみを呼び出すことができますが、サブプロシージャは呼び出すことができません。

面積が計算され、メッセージボックスにのみ表示されます。

面積値が関数から返されないため、結果セルにはゼロが表示されます。つまり、Excelワークシートからサブプロシージャを直接呼び出すことはできません。

VBA、イベント駆動型プログラミングは、セルまたはセル値の範囲を手動で変更したときにトリガーできます。変更イベントを使用すると作業が簡単になる場合がありますが、フォーマットでいっぱいのページをすばやく終了できます。イベントには2種類あります。

  • ワークシートイベント
  • ワークブックイベント

ワークシートイベント

ワークシートイベントは、ワークシートに変更があったときにトリガーされます。シートタブを右クリックして「コードの表示」を選択し、後でコードを貼り付けることで作成されます。

ユーザーは、これらのワークシートを1つずつ選択し、ドロップダウンから[ワークシート]を選択して、サポートされているすべてのワークシートイベントのリストを取得できます。

以下は、ユーザーが追加できるサポートされているワークシートイベントです。

Private Sub Worksheet_Activate() 
Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)    
Private Sub Worksheet_BeforeRightClick(ByVal Target As Range, Cancel As Boolean) 
Private Sub Worksheet_Calculate() 
Private Sub Worksheet_Change(ByVal Target As Range) 
Private Sub Worksheet_Deactivate() 
Private Sub Worksheet_FollowHyperlink(ByVal Target As Hyperlink) 
Private Sub Worksheet_SelectionChange(ByVal Target As Range)

ダブルクリックする前にメッセージを表示する必要があるとしましょう。

Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
   MsgBox "Before Double Click"
End Sub

出力

セルをダブルクリックすると、次のスクリーンショットに示すように、メッセージボックスがユーザーに表示されます。

ワークブックイベント

ワークブックイベントは、ワークブック全体に変更があったときにトリガーされます。次のスクリーンショットに示すように、ドロップダウンから[ThisWorkbook]を選択し、[workbook]を選択することで、ワークブックイベントのコードを追加できます。次のスクリーンショットに示すように、Workbook_openサブプロシージャがユーザーにすぐに表示されます。

以下は、ユーザーが追加できるサポートされているワークブックイベントです。

Private Sub Workbook_AddinUninstall() 
Private Sub Workbook_BeforeClose(Cancel As Boolean) 
Private Sub Workbook_BeforePrint(Cancel As Boolean) 
Private Sub Workbook_BeforeSave(ByVal SaveAsUI As Boolean, Cancel As Boolean) 
Private Sub Workbook_Deactivate() 
Private Sub Workbook_NewSheet(ByVal Sh As Object) 
Private Sub Workbook_Open() 
Private Sub Workbook_SheetActivate(ByVal Sh As Object) 
Private Sub Workbook_SheetBeforeDoubleClick(ByVal Sh As Object, ByVal Target As Range, Cancel As Boolean) 
Private Sub Workbook_SheetBeforeRightClick(ByVal Sh As Object, ByVal Target As Range, Cancel As Boolean) 
Private Sub Workbook_SheetCalculate(ByVal Sh As Object) 
Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range) 
Private Sub Workbook_SheetDeactivate(ByVal Sh As Object) 
Private Sub Workbook_SheetFollowHyperlink(ByVal Sh As Object, ByVal Target As Hyperlink) 
Private Sub Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range) 
Private Sub Workbook_WindowActivate(ByVal Wn As Window) 
Private Sub Workbook_WindowDeactivate(ByVal Wn As Window) 
Private Sub Workbook_WindowResize(ByVal Wn As Window)

新しいシートが作成されるたびに、新しいシートが正常に作成されたことを示すメッセージをユーザーに表示する必要があるとしましょう。

Private Sub Workbook_NewSheet(ByVal Sh As Object)
   MsgBox "New Sheet Created Successfully"
End Sub

出力

新しいExcelシートを作成すると、次のスクリーンショットに示すように、ユーザーにメッセージが表示されます。

プログラミングのエラーには、(a)構文エラー、(b)ランタイムエラー、および(c)論理エラーの3種類があります。

構文エラー

構文エラーは、解析エラーとも呼ばれ、VBScriptの解釈時に発生します。たとえば、次の行では、閉じ括弧がないため、構文エラーが発生します。

Function ErrorHanlding_Demo()
   dim x,y
   x = "Tutorialspoint"
   y = Ucase(x
End Function

Runtime errors

Runtime errors, also called exceptions, occur during execution, after interpretation.

For example, the following line causes a runtime error because here the syntax is correct but at runtime it is trying to call fnmultiply, which is a non-existing function.

Function ErrorHanlding_Demo1()
   Dim x,y
   x = 10
   y = 20
   z = fnadd(x,y)
   a = fnmultiply(x,y)
End Function

Function fnadd(x,y)
   fnadd = x + y
End Function

Logical Errors

Logical errors can be the most difficult type of errors to track down. These errors are not the result of a syntax or runtime error. Instead, they occur when you make a mistake in the logic that drives your script and you do not get the result you expected.

You cannot catch those errors, because it depends on your business requirement what type of logic you want to put in your program.

For example, dividing a number by zero or a script that is written which enters into infinite loop.

Err Object

Assume if we have a runtime error, then the execution stops by displaying the error message. As a developer, if we want to capture the error, then Error Object is used.

Example

In the following example, Err.Number gives the error number and Err.Description gives the error description.

Err.Raise 6   ' Raise an overflow error.
MsgBox "Error # " & CStr(Err.Number) & " " & Err.Description
Err.Clear   ' Clear the error.

Error Handling

VBA enables an error-handling routine and can also be used to disable an error-handling routine. Without an On Error statement, any run-time error that occurs is fatal: an error message is displayed, and the execution stops abruptly.

On Error { GoTo [ line | 0 | -1 ] | Resume Next }

シニア番号 キーワードと説明
1

GoTo line

必要な行引数で指定された行から開始するエラー処理ルーチンを有効にします。指定された行は、On Errorステートメントと同じ手順である必要があります。そうでない場合、コンパイル時エラーが発生します。

2

GoTo 0

現在のプロシージャで有効になっているエラーハンドラを無効にし、Nothingにリセットします。

3

GoTo -1

現在のプロシージャで有効になっている例外を無効にし、Nothingにリセットします。

4

Resume Next

実行時エラーが発生した場合、エラーが発生したステートメントの直後のステートメントに制御が移り、その時点から実行が継続されることを指定します。

Public Sub OnErrorDemo()
   On Error GoTo ErrorHandler   ' Enable error-handling routine.
   Dim x, y, z As Integer
   x = 50
   y = 0
   z = x / y   ' Divide by ZERO Error Raises
  
   ErrorHandler:    ' Error-handling routine.
   Select Case Err.Number   ' Evaluate error number.
      Case 10   ' Divide by zero error
         MsgBox ("You attempted to divide by zero!")
      Case Else
         MsgBox "UNKNOWN ERROR  - Error# " & Err.Number & " : " & Err.Description
   End Select
   Resume Next
End Sub

VBAを使用してプログラミングする場合、ユーザーが扱う重要なオブジェクトはほとんどありません。

  • アプリケーションオブジェクト
  • ワークブックオブジェクト
  • ワークシートオブジェクト
  • 範囲オブジェクト

アプリケーションオブジェクト

Applicationオブジェクトは、次のもので構成されます。

  • アプリケーション全体の設定とオプション。
  • ActiveCell、ActiveSheetなどのトップレベルオブジェクトを返すメソッド。

'Example 1 :
Set xlapp = CreateObject("Excel.Sheet") 
xlapp.Application.Workbooks.Open "C:\test.xls"

'Example 2 :
Application.Windows("test.xls").Activate

'Example 3:
Application.ActiveCell.Font.Bold = True

ワークブックオブジェクト

WorkbookオブジェクトはWorkbooksコレクションのメンバーであり、現在MicrosoftExcelで開いているすべてのWorkbookオブジェクトが含まれています。

'Ex 1 : To close Workbooks
Workbooks.Close

'Ex 2 : To Add an Empty Work Book
Workbooks.Add

'Ex 3: To Open a Workbook
Workbooks.Open FileName:="Test.xls", ReadOnly:=True

'Ex : 4 - To Activate WorkBooks
Workbooks("Test.xls").Worksheets("Sheet1").Activate

ワークシートオブジェクト

WorksheetオブジェクトはWorksheetsコレクションのメンバーであり、ブック内のすべてのWorksheetオブジェクトが含まれています。

'Ex 1 : To make it Invisible
Worksheets(1).Visible = False

'Ex 2 : To protect an WorkSheet
Worksheets("Sheet1").Protect password:=strPassword, scenarios:=True

範囲オブジェクト

範囲オブジェクトは、セル、行、列、またはセルの1つ以上の連続ブロックを含むセルの選択を表します。

'Ex 1 : To Put a value in the cell A5
Worksheets("Sheet1").Range("A5").Value = "5235"

'Ex 2 : To put a value in range of Cells
Worksheets("Sheet1").Range("A1:A4").Value = 5

VBAを使用して、Excelファイルを読み取り、セルの内容をテキストファイルに書き込むこともできます。VBAを使用すると、ユーザーは2つの方法を使用してテキストファイルを操作できます。

  • ファイルシステムオブジェクト
  • 書き込みコマンドの使用

ファイルシステムオブジェクト(FSO)

名前が示すように、FSOは、開発者がドライブ、フォルダー、およびファイルを操作するのに役立ちます。このセクションでは、FSOの使用方法について説明します。

シニア番号 オブジェクトタイプと説明
1

Drive

ドライブはオブジェクトです。システムに接続されているドライブに関する情報を収集できるようにするメソッドとプロパティが含まれています。

2

Drives

ドライブはコレクションです。物理的または論理的に、システムに接続されているドライブのリストを提供します。

3

File

ファイルはオブジェクトです。これには、開発者がファイルを作成、削除、または移動できるようにするメソッドとプロパティが含まれています。

4

Files

ファイルはコレクションです。フォルダ内に含まれるすべてのファイルのリストを提供します。

5

Folder

フォルダはオブジェクトです。開発者がフォルダを作成、削除、または移動できるようにするメソッドとプロパティを提供します。

6

Folders

フォルダはコレクションです。フォルダ内のすべてのフォルダのリストを提供します。

7

TextStream

TextStreamはオブジェクトです。これにより、開発者はテキストファイルの読み取りと書き込みを行うことができます。

ドライブ

Driveはオブジェクトであり、特定のディスクドライブまたはネットワーク共有のプロパティへのアクセスを提供します。次のプロパティはによってサポートされていますDrive オブジェクト-

  • AvailableSpace
  • DriveLetter
  • DriveType
  • FileSystem
  • FreeSpace
  • IsReady
  • Path
  • RootFolder
  • SerialNumber
  • ShareName
  • TotalSize
  • VolumeName

Step 1− FSOを使用したスクリプト作成に進む前に、Microsoft ScriptingRuntimeを有効にする必要があります。同じことを行うには、次のスクリーンショットに示すように、[ツール]→[参照]に移動します。

Step 2 −「MicrosoftScripting RunTime」を追加し、「OK」をクリックします。

Step 3 −テキストファイルに書き込みたいデータを追加し、コマンドボタンを追加します。

Step 4 −スクリプトを作成するときが来ました。

Private Sub fn_write_to_text_Click()
   Dim FilePath As String
   Dim CellData As String
   Dim LastCol As Long
   Dim LastRow As Long
  
   Dim fso As FileSystemObject
   Set fso = New FileSystemObject
   Dim stream As TextStream
  
   LastCol = ActiveSheet.UsedRange.Columns.Count
   LastRow = ActiveSheet.UsedRange.Rows.Count
    
   ' Create a TextStream.
   Set stream = fso.OpenTextFile("D:\Try\Support.log", ForWriting, True)
  
   CellData = ""
  
   For i = 1 To LastRow
      For j = 1 To LastCol
         CellData = Trim(ActiveCell(i, j).Value)
         stream.WriteLine "The Value at location (" & i & "," & j & ")" & CellData
      Next j
   Next i
  
   stream.Close
   MsgBox ("Job Done")
End Sub

出力

スクリプトを実行するときは、ワークシートの最初のセルにカーソルを置いてください。Support.logファイルは、次のスクリーンショットの「D:\ Try」に示すように作成されます。

ファイルの内容を次のスクリーンショットに示します。

コマンドの書き込み

FSOとは異なり、参照を追加する必要はありませんが、ドライブ、ファイル、およびフォルダーを操作することはできません。ストリームをテキストファイルに追加するだけで済みます。

Private Sub fn_write_to_text_Click()
   Dim FilePath As String
   Dim CellData As String
   Dim LastCol As Long
   Dim LastRow As Long
  
   LastCol = ActiveSheet.UsedRange.Columns.Count
   LastRow = ActiveSheet.UsedRange.Rows.Count
    
   FilePath = "D:\Try\write.txt"
   Open FilePath For Output As #2
  
   CellData = ""
   For i = 1 To LastRow
      For j = 1 To LastCol
         CellData = "The Value at location (" & i & "," & j & ")" & Trim(ActiveCell(i, j).Value)
         Write #2, CellData
      Next j
   Next i
  
   Close #2
   MsgBox ("Job Done")
End Sub

出力

スクリプトを実行すると、次のスクリーンショットに示すように、「write.txt」ファイルが「D:\ Try」の場所に作成されます。

ファイルの内容を次のスクリーンショットに示します。

VBAを使用すると、特定の基準に基づいてグラフを生成できます。例を使って見てみましょう。

Step 1 −グラフを生成する必要のあるデータを入力します。

Step 2 − 3つのボタンを作成します。1つは棒グラフを生成し、もう1つは円グラフを生成し、もう1つは縦棒グラフを生成します。

Step 3 −これらのタイプのチャートをそれぞれ生成するマクロを開発します。

' Procedure to Generate Pie Chart
Private Sub fn_generate_pie_graph_Click()
   Dim cht As ChartObject
   For Each cht In Worksheets(1).ChartObjects
      cht.Chart.Type = xlPie
   Next cht
End Sub

' Procedure to Generate Bar Graph
Private Sub fn_Generate_Bar_Graph_Click()
   Dim cht As ChartObject
   For Each cht In Worksheets(1).ChartObjects
      cht.Chart.Type = xlBar
   Next cht
End Sub

' Procedure to Generate Column Graph
Private Sub fn_generate_column_graph_Click()
   Dim cht As ChartObject
   For Each cht In Worksheets(1).ChartObjects
      cht.Chart.Type = xlColumn
   Next cht
End Sub

Step 4−対応するボタンをクリックすると、チャートが作成されます。次の出力で、[円グラフの生成]ボタンをクリックします。

A User Formは、ユーザーデータ入力をより制御しやすく、ユーザーにとって使いやすいようにするカスタムビルドのダイアログボックスです。この章では、単純なフォームを設計し、Excelにデータを追加する方法を学習します。

Step 1− Alt + F11を押してVBAウィンドウに移動し、[挿入]メニューに移動して[ユーザーフォーム]を選択します。選択すると、次のスクリーンショットに示すようにユーザーフォームが表示されます。

Step 2 −指定されたコントロールを使用してフォームをデザインします。

Step 3−各コントロールを追加した後、コントロールに名前を付ける必要があります。キャプションはフォームに表示されるものに対応し、名前はその要素のVBAコードを記述したときに表示される論理名に対応します。

Step 4 −以下は、追加された各コントロールに対する名前です。

コントロール 論理名 キャプション
から frmempform 従業員フォーム
従業員IDラベルボックス empid 従業員ID
名ラベルボックス ファーストネーム ファーストネーム
姓ラベルボックス 苗字 苗字
dobラベルボックス ドブ 生年月日
mailidラベルボックス mailid 電子メールID
パスポートホルダーラベルボックス パスポートホルダー パスポートホルダー
EmpIDテキストボックス txtempid 適用できません
名のテキストボックス txtfirstname 適用できません
姓のテキストボックス txtlastname 適用できません
メールIDテキストボックス txtemailid 適用できません
日付コンボボックス cmbdate 適用できません
月コンボボックス cmbmonth 適用できません
年コンボボックス cmbyear 適用できません
はいラジオボタン radioyes はい
ラジオボタンなし ラジオノ 番号
送信ボタン btnsubmit 参加する
キャンセルボタン btncancel キャンセル

Step 5 −フォームを右クリックし、[コードの表示]を選択して、フォームの読み込みイベントのコードを追加します。

Step 6 −次のスクリーンショットに示すように、オブジェクトのドロップダウンから「ユーザーフォーム」を選択し、「初期化」メソッドを選択します。

Step 7 −フォームをロードしたら、テキストボックスがクリアされ、ドロップダウンボックスが入力され、ラジオボタンがリセットされていることを確認します。

Private Sub UserForm_Initialize()
   'Empty Emp ID Text box and Set the Cursor 
   txtempid.Value = ""
   txtempid.SetFocus
   
   'Empty all other text box fields
   txtfirstname.Value = ""
   txtlastname.Value = ""
   txtemailid.Value = ""
   
   'Clear All Date of Birth Related Fields
   cmbdate.Clear
   cmbmonth.Clear
   cmbyear.Clear
   
   'Fill Date Drop Down box - Takes 1 to 31
   With cmbdate
      .AddItem "1"
      .AddItem "2"
      .AddItem "3"
      .AddItem "4"
      .AddItem "5"
      .AddItem "6"
      .AddItem "7"
      .AddItem "8"
      .AddItem "9"
      .AddItem "10"
      .AddItem "11"
      .AddItem "12"
      .AddItem "13"
      .AddItem "14"
      .AddItem "15"
      .AddItem "16"
      .AddItem "17"
      .AddItem "18"
      .AddItem "19"
      .AddItem "20"
      .AddItem "21"
      .AddItem "22"
      .AddItem "23"
      .AddItem "24"
      .AddItem "25"
      .AddItem "26"
      .AddItem "27"
      .AddItem "28"
      .AddItem "29"
      .AddItem "30"
      .AddItem "31"
   End With
   
   'Fill Month Drop Down box - Takes Jan to Dec
   With cmbmonth
      .AddItem "JAN"
      .AddItem "FEB"
      .AddItem "MAR"
      .AddItem "APR"
      .AddItem "MAY"
      .AddItem "JUN"
      .AddItem "JUL"
      .AddItem "AUG"
      .AddItem "SEP"
      .AddItem "OCT"
      .AddItem "NOV"
      .AddItem "DEC"
   End With
   
   'Fill Year Drop Down box - Takes 1980 to 2014
   With cmbyear
      .AddItem "1980"
      .AddItem "1981"
      .AddItem "1982"
      .AddItem "1983"
      .AddItem "1984"
      .AddItem "1985"
      .AddItem "1986"
      .AddItem "1987"
      .AddItem "1988"
      .AddItem "1989"
      .AddItem "1990"
      .AddItem "1991"
      .AddItem "1992"
      .AddItem "1993"
      .AddItem "1994"
      .AddItem "1995"
      .AddItem "1996"
      .AddItem "1997"
      .AddItem "1998"
      .AddItem "1999"
      .AddItem "2000"
      .AddItem "2001"
      .AddItem "2002"
      .AddItem "2003"
      .AddItem "2004"
      .AddItem "2005"
      .AddItem "2006"
      .AddItem "2007"
      .AddItem "2008"
      .AddItem "2009"
      .AddItem "2010"
      .AddItem "2011"
      .AddItem "2012"
      .AddItem "2013"
      .AddItem "2014"
   End With
   
   'Reset Radio Button. Set it to False when form loads.
   radioyes.Value = False
   radiono.Value = False

End Sub

Step 8−ここで、[送信]ボタンにコードを追加します。送信ボタンをクリックすると、ユーザーはワークシートに値を追加できるようになります。

Private Sub btnsubmit_Click()
   Dim emptyRow As Long
  
   'Make Sheet1 active
   Sheet1.Activate
  
   'Determine emptyRow
   emptyRow = WorksheetFunction.CountA(Range("A:A")) + 1
  
   'Transfer information
   Cells(emptyRow, 1).Value = txtempid.Value
   Cells(emptyRow, 2).Value = txtfirstname.Value
   Cells(emptyRow, 3).Value = txtlastname.Value
   Cells(emptyRow, 4).Value = cmbdate.Value & "/" & cmbmonth.Value & "/" & cmbyear.Value
   Cells(emptyRow, 5).Value = txtemailid.Value
  
   If radioyes.Value = True Then
      Cells(emptyRow, 6).Value = "Yes"
   Else
      Cells(emptyRow, 6).Value = "No"
   End If
End Sub

Step 9 −ユーザーが[キャンセル]ボタンをクリックしたときにフォームを閉じるメソッドを追加します。

Private Sub btncancel_Click()
   Unload Me
End Sub

Step 10−「実行」ボタンをクリックしてフォームを実行します。フォームに値を入力し、[送信]ボタンをクリックします。次のスクリーンショットに示すように、値は自動的にワークシートに流れ込みます。