• ベストアンサー

AccessVBAで実行時間を指定するには

よろしくお願いします。 VBAで指定した時間に処理(関数)を呼び出すという事がしたくて色々調べていたらApplication.Ontime というやつでなんとかできそうだとメドが立った ・・・つもりでいたのですが、どうやらこれはExcelの機能のようでした。 参照設定でエクセルのオブジェクトライブラリをチェックしたらAccessVBAで  >Excel.Application.Ontime 待ち時間, コマンドA と記述することでひとまず実行予約的な事まではできたのですが、 指定時間になると「コマンドAが見つかりません」 というエラーメッセージが出てしまいます。 おそらくエクセルのマクロを実行しようとして「見つからない」と言われているのでは無いかと考えています。 長くなりましたが質問は、上記のようなコードで、Accessのマクロ(関数)を呼び出すにはどうすれば良いのでしょうか? よろしくお願いします。 上記の前提が勘違いの場合は併せてご指摘頂ければ幸いです。

質問者が選んだベストアンサー

  • ベストアンサー
  • DexMachina
  • ベストアンサー率73% (1287/1744)
回答No.3

横レス失礼します。 > OnTimeメソッドにこだわる必要もなくなりつつあるのですが。 Accessからの呼び出しでしたら、Access(とAPI)で対応された方が よいとは思いますが、何かの参考に、ということで・・・ Excel.Application上のOnTimeを使用する場合、指定できるのは Excel.Applicationの管理下にあるものになりますので、Excel VBAで 当該マクロ(コマンドA)を呼び出すSubを作成し、Access上からこれを 呼び出す形になるかと思います。 (「Access→Excel→Access」と、相互に参照するような形) 【Excel側】 以下のマクロを、適当なExcelファイルの標準モジュールとして保存します。 OnTimeを使用してコマンドAを実行する際には、一旦このファイルを 開いて、下記Subを実行する、という流れになります。 Public Sub コマンドB() On Error GoTo エラー処理   Dim Acc As Object   '「OnTime」を呼び出したAccess(=ここではdb1.mdb)を捕捉   Set Acc = GetObject("c:\db1.mdb")   'db1.mdbで作成された「コマンドA」マクロを実行   Acc.Application.Run "コマンドA" 終了処理:  '念のため、メモリを解放 Set Acc = Nothing Exit Sub エラー処理: MsgBox Err & ":" & Error$, , "CallAccess" Resume 終了処理 End Sub 【Access側】 「OnTime」を使用する前に、上記Excelファイルを開きます。 「OnTime」では「コマンドA」を直接呼び出す代わりに、Excelから 「コマンドA」を間接的に呼び出す「コマンドB」を実行させます。 Public Sub コマンドC() On Error GoTo エラー処理   Dim Xls As Object   '上記で保存したExcelファイル(=ここではwb1.xls)を開く   Set Xls = CreateObject("Excel.Application")   Xls.Workbooks.Open "c:\wb1.xls"   '「OnTime」を使用して、「コマンドB」経由で「コマンドA」を実行   Xls.OnTime 待ち時間, "コマンドB" 終了処理   'エラー時も含めて、確実にExcelを終了させる   If Not (Xls Is Nothing) Then Xls.Quit   'メモリの解放   Set Xls = Nothing   Exit Sub エラー処理:   MsgBox Err & ":" & Error$, , "Test"   Resume 終了処理 End Sub ・・・以上です。 なお、蛇足になりますが、No.2の回答は、No.1の方と全く同じこと (=Timerイベントの使用)を言っているだけでしょうから(下記参照)、 既にTimerイベント等で対応が取れているのでしたら、リンク先の 内容は気にする必要はないかと思います。 以下は推測の根拠(例): http://oshiete1.goo.ne.jp/qa5196729.html http://oshiete1.goo.ne.jp/qa5193921.html

akirou
質問者

お礼

丁寧なご回答に加えサンプルコードまで頂き、ありがとうございます。 やはりExcel.Applicationの管理下のものじゃないと駄目なんですね、当然といえば当然ですが(汗 プログラミングって「できる」と言うのは簡単ですが「出来ない」と言い切るのは大変なので、どうしても「他に方法は無いのかな?」と気になってしまい、他の方法で出来てるならいいじゃないか、と思いつつもなかなか振り切れないのが自分の悪い癖だと思いつつなかなか性格は直りません(TT) とても参考になりました、ありがとうございました。

その他の回答 (2)

  • imogasi
  • ベストアンサー率27% (4737/17068)
回答No.2

参考質問 http://www.accessclub.jp/bbs/0201/beginers62477.html 終わりの方のリンクページ。

akirou
質問者

お礼

回答ありがとうございます。 参考リンク先を全て理解しきれていなのですが、 「外出しのVBSにしてコマンド実行すれば?」と仰ってますでしょうか? 今回の質問で一番知りたいのは、 Excel.Application.Ontime 待ち時間, コマンドA ~~~~~~ とした場合、この「コマンドA」はエクセルのマクロブックから探しにいくしかないのか? そうだとした場合アクセスのマクロを実行する(簡単な)方法はないのか? という事です。 よろしくお願いします。

  • ShowMeHow
  • ベストアンサー率28% (1424/5027)
回答No.1

フォームのイベントの「タイマー時」を使うのが良いと思います。

akirou
質問者

お礼

回答ありがとうございます。 現在は暫定対応としてフォームのタイマーイベントやらループやらスリープ(API)を織り交ぜて実装してます。 まあこれはこれでいい感じなのでいまさらOnTimeメソッドにこだわる必要もなくなりつつあるのですが。

関連するQ&A

  • エクセル時間毎ごとにマクロを実行するやり方。

     初めまして、よろしくお願いします。より正確な指定時間毎にマクロを実行させるやり方を考えています。  1分毎ごとにマクロを実行する nextTime = Now() + TimeValue("00:01:00") Application.OnTime nextTime, "時間毎ごとに実行" というやり方は解るのですが、 Application.OnTime TimeValue("09:00:00"), "時間毎ごとに実行"  この指定時間("09:00:00")に実行するマクロを利用し ("09:01:00")、("09:02:00")、("09:03:00")、("09:04:00")、("09:05:00"),・・・・・の時間、秒が00になると("hh:ss:00")マクロを実行されるやり方は有るのでしょうか。  もし有るのでしたら、よろしくお願いします。

  • 指定時間に自動実行

    いつもお世話になっております。 早速ですが、 OFFICEXP EXCELでデータを更新するプロシージャを指定時間に実行させたいのですが、どのようにしたら良いのでしょうか。 Ontimeを使用してみたのですがまったく動きません。 Sub Ontime() Object.OnTime earliesttime:=("10:30:00"), procedure:="オートシェイプ28_Click", schedule:=True End Sub 超初心者なのでよろしくお願いします。

  • VB2010 で指定時間にプロシジャ起動するには?

    検索の仕方なのか、判らないので教えてください。 ExcelのVBAではApplication.OnTime メソッドがあり、 Application.OnTime TimeValue("17:00:00"), "test01" とすれば、17時ちょうどにtest01というプロシージャが実行されます。 フォームを作って Application.OnTime UserForm1.TextBox1.Value, "test01" のようにすれば、TextBox1に時間指定して、その指定時間にtest01を起動する事も可能で、業務用アプリとして実際に使用しています。 では、これをVisual Basic 2010で同じように実行するにはどうしたら可能でしょうか? googleで調べても、時計のように、一定時間(1秒ごと)にラベルの内容を書き換え表示するようなサンプルは見つかるのですが、指定時間に、指定の処理を実行する というようなサンプルは見つかりませんでした。 指定時間にFTPにファイルをアップしたり、指定時間にWEBブラウザからHTMLを取得したりと、いろいろ使い道があって結構つかっていますので、この「指定した時間に、処理○○を記述したプロシージャーを実行して」という処理ができないとかなり困ります。

  • 指定した時刻になるとセルに色がつくようにしたい

    初心者です。エクセルのVBAで設定した時刻になったらセルに色がつくようにしたいです。 例えば、17:00時にA1セル、18:00にA2セルに色を自動でつくようにしたいと思っています。 OnTimeを使ったらよいと思っていろいろ試しましたが、設定した時刻になってもなにも起こりません。 標準モジュールに以下の内容を記述して、パソコンの時計を変更して確認しています。 できたらクリックしないでファイルオープンしてなにもせずに設定時刻に実行されるようにしたいです。 最初の3秒でB1に現在の時間を取得。 セルA1とA2をクリアしてから設定時間に色をつけるようにしたつもりです。 下記が記述内容です。 Sub 指定時間にマクロを開始() Dim stime As Date Range("A1") = "" Range("A2") = "" Range("B1").Select stime = Now + TimeValue("00:00:03") Application.OnTime TimeValue(stime), "マクロ実行内容", TimeValue("00:05:00") End Sub Sub 時刻の設定1() Application.OnTime EarliestTime:=TimeValue("17:00:00"), Procedure:="Test" End Sub Sub Procedure() Range("A1").Interior.ColorIndex = 8 End Sub Sub 時刻の設定2() Application.OnTime EarliestTime:=TimeValue("18:00:00"), Procedure:="Test" End Sub Sub Procedure2() Range("A2").Interior.ColorIndex = 9 End Sub 実行マクロは有効にしています。 ご教授よろしくお願いします。

  • VBA 指定時間で実行

    あるマクロを指定時間で実行するのは可能でしょうか? Call TEST と呼び出す方法はあるのでしょうか?もしないとしたら、ほかに方法はありますでしょうか?

  • 「一定の時間間隔で5秒毎にマクロを実行する」

    Timer関数を使ったループ 「一定の時間間隔で5秒毎にマクロを実行する」 ようにしてMacro1を実行したいのですが、 うまくいきません。どう改変したらいいでしょうか。 Sub Macro2() Dim tt As Double Dim wt As Double tt = Now + TimeValue("00:00:05") '5秒後 wt = TimeValue("00:00:01") 'インターバル1秒 Application.OnTime TimeValue("00:00:05"), "Macro1", TimeValue("00:00:01") End Sub

  • 指定した時間に実行するマクロ

    Sub データー削除() Sheets("Sheet2").Select Rows("3:17").Select Selection.ClearContents Range("A1").Select ActiveWorkbook.Save ActiveWorkbook.Close End Sub データーAというエクセルBOOKに 上記の単純なマクロが組み込まれています このBOOKは普段は常に閉じている状態です このBOOKがAM0:00に自動で開いて上記のマクロの実行できるように するにはどの様にしたらいいでしょうか? on timeとかいう方法を使うらしいでんすが使い方がよくわかりません

  • VBAを時間指定で自動実行

    就業時間内(9時~6時)でエクセルVBAを指定時間に自動実行させたいです。 エクセルはパソコン起動した朝に、開いておきます。(バックグラウンド) 指定時間になったらVBAを自動実行させたいのです。 指定時間は例えば、 10時11分 10時16分 10時21分 などです。最初の時間から5分間隔で実行。 こういう事はできるのでしょうか?VBAでできるのか? それ以外の方法があるのか?よくわかりません。 詳しく教えてください。

  • マクロと次のマクロ実行の間の時間を指定

    EXCELで、マクロを使ってSHEET1にワードアートを挿入し、 10秒経ってから(挿入した文字を読むための時間) SHEET2に別のワードアートを挿入したいと思っています。 SHEET1にワードアートを挿入するマクロ(マクロ1)の実行から SHEET2にワードアートを挿入するマクロ(マクロ2)実行までの 時間を指定するにはこの2つをどうつなげて記述すればよいでしょうか?

  • 「一定の時間間隔で5秒毎にMacro1を実行する」

    「一定の時間間隔で5秒毎にMacro1を実行する」 一応startマクロ、stopマクロは作成してみたのですが、 下記stopコマンド実行しても止まらなかったような気がします。 ここから改変するとしたらどうですか? Public timestop As Boolean Sub test() Dim tt As Double Dim wt As Double tt = Now + TimeValue("00:00:05") '5秒後 wt = TimeValue("00:00:02") 'インターバル2秒 Application.OnTime tt, "Macro1", wt If (timestop = False) Then Time = Timer Application.OnTime earliesttime:=(Now + TimeValue("00:00:01")), procedure:="test" End If End Sub ---------------------------------------- ここからstart,stopマクロ Sub t_start() timestop = False Call test End Sub Sub t_stop() timestop = True End Sub

専門家に質問してみよう