2
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Accessのマクロについての整理

Posted at

Access 2007 マクロの基本
Access for Office 365, Access 2019, Access 2016, Access 2013, Access 2010, Access 2007

英語の記事

この記事では、Access データベース内のマクロについて説明し、頻繁に実行するタスクを自動化することで時間を節約する方法についても説明します。 ここでは、マクロの作成と使用の基礎について説明し、Access でのマクロの改善にも触れます。

マクロとは

Access のマクロは、タスクを自動化したり、フォーム、レポート、コントロールに機能を追加したりするためのツールです。 たとえば、フォームにコマンドボタンを追加する場合は、ボタンのOnClickイベントをマクロに関連付けます。また、マクロには、ボタンをクリックするたびに実行されるコマンドが含まれています。

Access では、マクロを、実行するアクションのリストを作成して作成する単純なプログラミング言語と考えることができます。 マクロを作成するときは、各アクションをドロップダウン リストから選択し、アクションごとに必要な情報を入力します。 マクロを使用すると、Visual Basic for Applications (VBA) モジュールでコードを記述せずに、フォーム、レポート、コントロールに機能を追加できます。 マクロでは VBA で使用できるコマンドのサブセットが用意されており、マクロを作成する方が VBA コードを記述するより簡単だと感じるユーザーがほとんどです。
マクロを使ったコマンドボタンの作成

ユーザーインターフェイスマクロ

たとえば、データ入力フォームの1つからレポートを直接開始するとします。 フォームにボタンを追加して、レポートを開くマクロを作成できます。 マクロは、スタンドアロンのマクロ (データベース内の個別のオブジェクト) であり、ボタンのonclickイベントに連結されます。または、マクロはボタン自体のonclickイベントに直接埋め込むことができます。 いずれの方法でも、ボタンをクリックすると、マクロが実行され、レポートが表示されます。 通常、これらの種類のマクロは、ユーザーインターフェイスマクロと呼ばれます。

Access2010から導入されたデータマクロ

Access 2010 は、データマクロの概念を導入する最初のバージョンです。 データマクロを使用すると、タスクを自動化して、テーブルに機能を直接追加できます。 データマクロとその操作は、テーブルに新しいレコードを追加するときなど、特定のテーブルイベントに関連付けられています。

マクロビルダーを使用してマクロを作成する例を次の図に示します。

IntelliSense を使用して式を入力する
[図は省略]

注:

access 2010 以降では、access マクロを簡単に作成、変更、および共有できるように、マクロビルダーが再設計されています。 Access 2007 を使用している場合、マクロビルダーは、マクロのアクションと条件を定義する一連の行と列です。

マクロビルダーでユーザーインターフェイスマクロを表示するには、次の操作を行います。

  • [作成] タブの [マクロとコード] グループで [マクロ] をクリックします。

マクロビルダーでデータマクロを表示するには、次の操作を行います。

  • データシートビューで任意のテーブルを開きます。 [テーブル] タブの [ Before events and after events ] グループで、[変更前] または [挿入後] など、いずれかのイベントコマンドをクリックします。

マクロビルダーの詳細と、ユーザーインターフェイスやデータマクロの作成とテストの方法については、この記事の最後にある「関連項目」を参照してください。

Access のマクロ機能

新しい機能とマクロアクションが追加、セキュリティの強化

以前のバージョンの Access では、VBA コードを記述せずによく使う関数の多くは実行できませんでした。 Access の現在のバージョンでは、コードを必要としないようにするために、新しい機能とマクロアクションが追加されています。 これにより、データベースに機能を追加して、セキュリティを強化することが簡単になります。

埋め込みマクロ(Embedded macros)

フォーム、レポート、またはコントロールによって提供されるイベントのいずれかにマクロを埋め込むことができます。 埋め込みマクロは、ナビゲーションウィンドウには表示されません。作成されたフォーム、レポート、またはコントロールの一部になります。 埋め込みマクロを含むフォーム、レポート、またはコントロールのコピーを作成した場合、マクロはコピーにも表示されます。
埋め込みマクロはVBAに簡単に変換できない

セキュリティの強化

マクロビルダーで [すべてのアクションを表示] ボタンが強調表示されていない場合、使用できるマクロアクションと RunCommand 引数は、信頼済み状態の実行を必要としないものだけです。 これらのアクションで作成されたマクロは、データベースが無効モードになっている場合でも実行されます (VBA が実行できない場合)。 信頼できるリストにないマクロアクションを含むデータベース、または VBA コードのあるデータベースには、信頼された状態を明示的に付与する必要があります。
Accessのマクロで選択したいアクションが一覧にない場合の対処方法
データマクロ もう一度学ぶMS-Access

エラー処理とデバッグ

Access provides macro actions, including OnError (similar to the "On Error" statement in VBA) and ClearMacroError, that allow you to perform specific actions when errors occur while your macro is running. In addition, the SingleStep macro action allows you to enter single-step mode at any point in your macro, so that you can observe how your macro works one action at a time.
アクセスは~~[ z0z_ _ _ ] ~~マクロアクションを提供します。これにより、マクロの実行中にエラーが発生すると、エラーが発生したときに特定の操作を実行できるようになります (VBA の "On Error" ステートメントに似ています)。 clearmacroerrorを使用します。 また、" SingleStep/シングルステップ" マクロアクションを使用すると、マクロの任意のポイントにシングルステップモードにして、マクロの動作を一度に1つずつ確認することができます。

一時変数

3つのマクロアクション (settempvar、 removetempvar、およびRemoveAllTempVars) を使用すると、マクロで一時変数を作成して使うことができます。 これらは、条件式で使用して、マクロの実行を制御したり、レポートやフォームにデータを渡したり、値の一時的な格納場所を必要とするその他の目的で使用したりできます。 これらの一時変数は、vba でもアクセスできるため、vba モジュールとの間でデータをやり取りするために使用することもできます。

マクロアクションの詳細について

マクロビルダーで作業しているときに、アクションまたは引数の詳細については、アクションまたは引数をクリックして、マクロビルダーウィンドウの右下隅にあるボックスの説明を参照してください。 また、各マクロアクションにはヘルプ記事が関連付けられています。 アクションの詳細については、アクションリストでアクションをクリックし、F1 キーを押します。

関連項目
ユーザーインターフェイス (UI) マクロを作成する
Access 2010 Later
Microsoft Access では、コマンド ボタン、テキスト ボックス、フォーム、レポートなどのユーザー インターフェイス (UI) オブジェクトに添付されるマクロを UI マクロと呼びます。 テーブルに添付されるデータ マクロとは区別されます。 (UI) マクロを使うのは、別のオブジェクトを開いたり、フィルターを適用したり、エクスポート操作を始めたりというような一連のアクションおよびその他多くのタスクを自動化するためです。 この記事では、新しく設計しなおされたマクロ ビルダーを紹介し、UI マクロの作成に関連する、基本的なタスクについて説明します。

概要
新機能
スタンドアロン マクロを作成する
埋め込みマクロを作成する
アクションをマクロに追加する
If、Else If、Else によってプログラム フローを制御する
サブマクロを作成する
関連アクションをグループにまとめる
マクロ アクションまたはブロックの展開と折りたたみ
マクロ アクションのコピーと貼り付け
他のユーザーとマクロを共有する
マクロを実行する
マクロをデバッグする
マクロを VBA コードに変換する

データマクロを作成する
Access のデータマクロを使用すると、データの追加、更新、削除など、テーブル内で発生するイベントにロジックを追加することができます。 これらは、Microsoft SQL Server の "triggers" に似ています。 この記事では、データマクロを作成してデバッグする方法について説明します。

データマクロについて
イベントドリブンデータマクロを作成する
名前付きデータマクロを作成する
データマクロを管理する
デバッグデータマクロ

データベースを開いたときに実行されるマクロを作成
Access 2007 Later
Access データベースを起動するたびに特定の一連のアクションを実行するには、AutoExec マクロを作成できます。たとえば、アプリケーション ウィンドウを自動的に最大化し、ナビゲーション ウィンドウをロックして、特定のレポートを開く場合があります。
AutoExec マクロは、単に AutoExec という名前が付けられたマクロです。データベースの起動時、Access で他のマクロや VBA コードが実行される前に、AutoExec マクロが実行されます。
AutoExec マクロおよび他の起動オプションを省略するには、Shift キーを押しながらデータベースを起動します。
注: この記事は、Access Web データベースまたは Access Web アプリには適用されません。
シングルステップモードを使用してマクロをテストする
ステップ スルーでマクロを修正する
※リンクとタイトルが違う
Test a macro by using Single Step mode
Single Stepモードを使うことによってマクロをテストする
zsk (z0z_ ) を使用すると、マクロの流れと、各z2z_の結果を確認して、エラーの原因となった操作や望ましくない結果を返すアクションを分離することができます。
シングルステップモードを使用するとマクロの流れ(Flow)と各アクションごとの結果を確認し、エラーの原因となった操作や望ましくない結果を返すアクションを修正、削除(isolate)することができます

  • マクロの実行中にシングルステップを開始するには、ctrl キーを押しながら BREAK キーを押します。
  • マクロの特定のポイントでシングルステップを開始するには、シングルステップを開始する位置で "SingleStep/シングルステップ"マクロアクションをマクロに追加します。 次の手順を使用して、マクロに " SingleStep/シングルステップ" マクロアクションを追加します。
[Access プログラミングの概要](https://support.office.com/ja-jp/article/access-%E3%83%97%E3%83%AD%E3%82%B0%E3%83%A9%E3%83%9F%E3%83%B3%E3%82%B0%E3%81%AE%E6%A6%82%E8%A6%81-92eb616b-3204-4121-9277-70649e33be4f#bmlearnaboutmacros)

注:

多くの Microsoft Office プログラムでは、"マクロ" という用語は VBA コードを指すために使用されます。Access での "マクロ" という用語は、マクロ ビルダーを使用して収集できる、マクロ アクションの名前付きコレクションを指すため、Access ユーザーにとっては、これが混乱の元になる場合があります。Access のマクロ アクションとは、VBA で使用できるコマンドのサブセットのみを表します。マクロ ビルダーには Visual Basic エディターよりも構造化されたインターフェイスが用意されており、VBA コードを習得しなくてもコントロールおよびオブジェクトにプログラムを追加できます。
Access のヘルプ記事では、マクロと呼ばれるのは Access マクロであることを覚えておいてください。
これに対して VBA コードは、VBA、コード、関数、プロシージャのいずれかの名称で呼ばれます。VBA コードは、クラス モジュール (個々のフォームまたはレポートの一部で、通常、それらのオブジェクト専用のコードを含む) およびモジュール (特定のオブジェクトに関連付けられているのではなく、通常、データベース全体で使用できる "グローバル" なコードを含む) に含まれます。

プログラミングとは
マクロを使用する場合と VBA コードを使用する場合
コマンド ボタン ウィザードを使用して共通のプログラミング タスクを実行する
マクロを理解する
VBA コードを理解する
マクロを VBA コードに変換する

マクロ一覧(リンク)

Access2010マクロ アクション一覧
マクロは

  • ウィンドウ管理
  • システム コマンド(終了など)
  • データのインポート/エクスポート
  • データベース オブジェクト(コピー、追加)
  • データ入力操作
  • ユーザー インターフェイス コマンド(ツールバー、ナビゲーションの操作)
という分類になっている ## 公式の分類 [Access マクロのアクション (Access の開発者用リファレンス)](https://docs.microsoft.com/ja-jp/office/client-developer/access/desktop-database-reference/access-macro-actions-access-developer-reference)
  • プログラム フロー
    • If...Then...Else マクロ ブロック
    • Comment マクロ ステートメント
    • Group マクロ ステートメント
    • Submacro マクロ ステートメント
  • データ入力操作
    • DeleteRecord マクロ アクション
  • データのインポート/エクスポート
    • [RunSavedImportExport マクロ アクション](https://docs.microsoft.com/ja-jp/office/client-developer/access/desktop-database-reference/runsavedimportexport-macro-action)
    • EMailDatabaseObject マクロ アクション
    • ExportWithFormatting マクロ アクション
    • ImportExportData マクロ アクション
    • ImportExportSpreadsheet マクロ アクション
    • ImportExportText マクロ アクション
    • ImportSharePointList マクロ アクション
  • データベース オブジェクト
    • CopyObject マクロ アクション
    • DeleteObject マクロ アクション
    • GoToControl マクロ アクション
    • GoToPage マクロ アクション
    • GoToRecord マクロ アクション
    • OpenForm マクロ アクション
    • OpenReport マクロ アクション
    • OpenTable マクロ アクション
    • RenameObject マクロ アクション
    • SaveObject マクロ アクション
    • SelectObject マクロ アクション
    • SetProperty マクロ アクション
    • RepaintObject マクロ アクション
    • SetValue マクロ アクション
  • フィルター/クエリ/検索
    • ApplyFilter マクロ アクション
    • FindNextRecord マクロ アクション
    • FindRecord マクロ アクション
    • OpenQuery マクロ アクション
    • RefreshRecord マクロ アクション
    • Requery マクロ アクション
    • RunSQL マクロ アクション(ただしこのアクションは256文字までしか実行できない。他方Docmd.RunSQLは32000字まで可能。)
    • SearchForRecord マクロ アクション
    • SetFilter マクロ アクション
    • SetOrderBy マクロ アクション
    • ShowAllRecords マクロ アクション
  • マクロ コマンド
    • CancelEvent マクロ アクション
    • Echo マクロ アクション
    • ClearMacroError マクロ アクション
    • OnError マクロ アクション
    • OpenVisualBasicModule マクロ アクション
    • RemoveAllTempVars マクロ アクション
    • RemoveTempVar マクロ アクション
    • RunCode マクロ アクション
    • RunDataMacro マクロ アクション
    • RunMacro マクロ アクション
    • RunMenuCommand マクロ アクション
    • SetLocalVar マクロ アクション
    • SetTempVar マクロ アクション
    • SingleStep マクロ アクション
    • StartNewWorkflow マクロ アクション
    • StopAllMacros マクロ アクション
    • StopMacro マクロ アクション
    • WorkflowTasks マクロ アクション
  • System コマンド
    • Beep マクロ アクション
    • CloseDatabase マクロ アクション
    • DisplayHourglassPointer マクロ アクション
    • PrintOut マクロ アクション
    • QuitAccess マクロ アクション
    • RunApplication マクロ アクション
    • SendKeys マクロ アクション
    • SetWarnings マクロ アクション
  • ユーザー インターフェイス コマンド
    • AddMenu マクロ アクション
    • BrowseTo マクロ アクション
    • LockNavigationPane マクロ アクション
    • MessageBox マクロ アクション
    • NavigateTo マクロ アクション
    • SetDisplayedCategories マクロ アクション
    • SetMenuItem マクロ アクション
    • ShowToolbar マクロ アクション
  • ウィンドウ管理
    • CloseWindow マクロ アクション
    • MaximizeWindow マクロ アクション
    • MoveAndSizeWindow マクロ アクション
    • MinimizeWindow マクロ アクション
    • RestoreWindow マクロ アクション
  • データ ブロック
    • CreateRecord データ ブロック
    • EditRecord データ ブロック
    • ForEachRecord データ ブロック
    • LookupRecord データ ブロック
  • データ アクション
    • CancelRecordChange マクロ アクション
    • ClearMacroError マクロ アクション
    • ExitForEachRecord マクロ アクション
    • LogEvent マクロ アクション
    • OnError マクロ アクション
    • RaiseError マクロ アクション
    • SendEmail マクロ アクション
    • SetField マクロ アクション
    • SetLocalVar マクロ アクション
    • SetReturnVar マクロ アクション
    • DeleteRecord マクロ アクション
  • ADP のオブジェクト
    • CopyDatabaseFile マクロ アクション
    • OpenDiagram マクロ アクション
    • OpenFunction マクロ アクション
    • OpenStoredProcedure マクロ アクション
    • OpenView マクロ アクション
    • TransferSQLDatabase マクロ アクション
  • データ マクロ イベント
    • After Delete マクロ イベント
    • After Insert マクロ イベント
    • After Update マクロ イベント
    • Before Change マクロ イベント
    • Before Delete マクロ イベント
2
5
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
5

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?