Excel

DoEvents(マクロ実行中に画面操作する)

投稿日:2020年4月9日 更新日:

VBAの学習で、DoEventsを使ったシステムを作成したので今回記事にします。

まずは、シート上を以下のように準備します。

そして以下のソースコードを記述し、実行していきます。


Public StopFrag As Boolean                                          '一時停止フラグ
Dim inner As String                                                 'セルに入力する"123"格納用変数
Dim i As Integer                                                    '行位置カウント用変数
Private Declare Sub Sleep Lib "kernel32" (ByVal ms As Long)         'API使用のため宣言

'セルに"123"を記入していく。チェックボックスの状態により一時停止と再開を行う。
Sub スタート()



    i = 1
    inner = "123"


    Do While i < 21                                                 '20行まで
    
            DoEvents                                                '処理中でもチェックボックスが有効になる。
            StopFrag = ActiveSheet.CheckBox1.Value                  'チェックボックスの状態を(True or False)で取得する。

        
            Do While StopFrag = True                                'チェック有     チェックボックスのステータスを確認して中断、再開
            
                Sleep 500                                           'インターバル0.5秒
                DoEvents                                            '処理中でもチェックボックスが有効になる。
                StopFrag = ActiveSheet.CheckBox1.Value              'チェックボックスの状態を(True or False)で取得する。
                
            Loop
            

            
            
            Cells(i, 1).Value = inner                               '"123"をセル(1,1)から順に入力していく。
            i = i + 1                                               '次の行
    
        Sleep 500                                                   'インターバル0.5秒
    
    Loop

End Sub

実行するとA列に「123」が0.5秒おきに自動入力されていきます。

通常マクロ実行中はシート上の操作をしようとしても、画面描画されず、操作を受け付けませが、「DoEvents」を付けることにより、マクロ実行中でもシート上の操作を受け付けるようになります。

「stop」にチェックが無いと「StopFrag」がFalseとなる。
「stop」にチェックが入ると「StopFrag」がTrueとなる。

「stop」にチェックが入ると自動入力が一時停止となります。(見かけ的に止まっているように見えるだけで、裏では何もしないという処理が0.5秒ごとに繰り返されている)

そしてチェックが外れると自動入力が再開されます。

-Excel

執筆者:


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

関連記事

ファイルを移動させる[Name … As …]

今回はVBAでファイルを移動させる方法について記事にします。 まずはソースコードを準備します。 Sub ファイル移動() before_file_path = ThisWorkbook.Workshe …

【SAS】SASで良く使うテクニック。その1 Excel関数のIF~2テーブルを比較したいとき~

今回はSASで良く使うテクニックということで、2テーブルを比較するときはExcelでIF関数を使うと良い理由を解説していきます。 ぜひ、やってみてください。 まずは比較したいデータセット2つをExce …

セルに値を設定する【Excel】【VBA】

今回はExcelのセルに値を設定する方法をご紹介します。 以下のようにソースコードを記述します。 Sub 値設定() Dim a1 As String a1 = “あいうえお“ …

サクラエディタでVBAのステップ数を数える

サクラエディタの正規表現を使ってVBAソースコードのステップ数を数えてみたいと思います。 以下のソースを準備します。 Public StopFrag As Boolean ‘一時停止フラグ Dim i …

Excelのリスト化でファイルが壊れる件

訳あってVBAでセルをリスト化する機会があり、今回はその時躓いたことを記事にしました。 [目次] 1.起こったバグ2.原因3.対処法 1.起こったバグ セルをリスト化するものとして、今回は以下のソース …