No.6ベストアンサー
- 回答日時:
こんにちは。
Wendy02です。
たぶん、Web クエリとの連動のイベントの説明しても、違う環境で試されたのでは、おそらく実証できないでしょうから、OnTime メソッドで説明しておきます。
Sub ActionSetting()
Dim myTime As Date
myTime = Now()
For i = 0 To 360 '6時間 '1分ごと
Application.OnTime myTime + TimeValue("00:01:00") * i, "Move2RowTo21Row"
Next
End Sub
Private Sub Move2RowTo21Row()
Application.ScreenUpdating = False
With Rows(21)
.Insert
Rows(2).Copy Rows(21)
End With
Application.ScreenUpdating = True
End Sub
No.5
- 回答日時:
こんばんは。
>記述的には理解できないのでそのまま貼り付けてみましたが、動作はできませんでした。
#2と#3 は、話が続いているのですが、おそらくは、きちんと読んでいないのでしょうね。
とは言っても、Culculate イベントの実体が何かわからないと、ちょっと厳しいかもしれません。
>webクエリの更新時間と連動できるとなおよいです
連動ということで、私はのCulculateイベントを書いたわけで、Webクエリの更新が起動となるわけで、そのまま見ていても動くわけはありません。
でも、実際のマクロは見せられていないですから、話が続きませんね。私のほうの、OnTime イベントは、#4の専門家さんが書いておられますので、そのままにしておきますね。こちらのコードも見直していただければ、それはそれなりに考えますが。
お手数おかけしました。
動作させたいマクロ部分は↓のみですが
時間おきにループさせたいので困っています。
Rows("21:21").Select
Application.CutCopyMode = False
Selection.Insert Shift:=xlDown
Rows("2:2").Select
Selection.Copy
Rows("21:21").Select
ActiveSheet.Paste
Application.CutCopyMode = False
No.4
- 回答日時:
こんばんは。
お待たせしました。こんな例がありました。
どうでしょうか?
Testを実行するとSheet1をアクティブにして、A1:A10に"t.tanaka"を
書き込みます。そして15秒間何もせず、続いてB1:B10に"t.tanaka"を
書き込みます。処理の停止している15秒間は、Excelに対して通常の処理を
行えます。
【マクロ】
Sub Test()
Dim i As Integer
Sheets("Sheet1").Select
For i = 1 To 10
Cells(i,1) = "t.tanaka"
Next i
Application.OnTime Now + TimeValue("00:00:15"), "WaitTime"
End Sub
Sub WaitTime()
Dim i As Integer
For i = 1 To 10
Cells(i,2) = "t.tanaka"
Next i
End Sub
この回答への補足
マクロ自体は無限に実行したいのです。
↓で実行しましたがだめでした。
お手数ですが再度方法についてお願いします。
Sub Test()
Rows("21:21").Select
Application.CutCopyMode = False
Selection.Insert Shift:=xlDown
Rows("2:2").Select
Selection.Copy
Rows("21:21").Select
ActiveSheet.Paste
Application.CutCopyMode = False
Do
Application.OnTime Now + TimeValue("00:00:05"), "WaitTime"
Loop
End Sub
Sub WaitTime()
Rows("21:21").Select
Application.CutCopyMode = False
Selection.Insert Shift:=xlDown
Rows("2:2").Select
Selection.Copy
Rows("21:21").Select
ActiveSheet.Paste
Application.CutCopyMode = False
End Sub
ありがとうございます
部分的に理解できます
ここの環境にエクセルが入ってないので
明日会社で動作させて見ます
また、ご報告させていただきます。
No.3
- 回答日時:
追伸:
今、設定して気が付いたことですが、
Worksheet_Calculate() イベントは、Application 全体から影響を受けますから、他のシートを使っているときに、誤動作してしまう可能性があります。その場合、以下のようにしたらどうかと思います。
Dim blnActive As Boolean
Private Sub Worksheet_Activate()
blnActive = True
End Sub
Private Sub Worksheet_Change(ByVal Target As Range)
blnActive = False
End Sub
Private Sub Worksheet_Calculate()
If blnActive Then
'実行
End If
End Sub
ありがとうございました
記述的には理解できないのでそのまま貼り付けて
みましたが、動作はできませんでした。
すいません、お手数おかけしました。
No.2
- 回答日時:
こんばんは。
>マクロを1分おきに自動実行する
と
>webクエリの更新時間と連動できるとなおよいです
とはExcelの場合は、たぶん別ですね。
例えば、Web クエリを更新するには、以下のようになるかと思いますが、Webクエリ側で、バックグラウンドで動かすとか、更新の周期とかは、オフにする必要があると思います。
だから、連動というよりも、QueryTable Refresh に、マクロを取り付けなくてはなりません。そうでないとしたら、以下のように、Caluculate イベントに、マクロを取り付ければよいと思います。
Sub QueryTableRefresh()
On Error Resume Next
ActiveSheet.QueryTables(1).Refresh
End Sub
Sub ActionSetting()
Dim myTime As Date
myTime = Now()
For i = 1 To 60 '1時間
Application.OnTime myTime + TimeValue("00:01:00") * i, "QueryTableRefresh"
Next
End Sub
'------------------------------------------------
もしも、Web クエリと連動させるのでしたら、
同じシートで、Web情報に関わらないエリアのセルに、
=Now()
と入れて、
Private Sub Worksheet_Calculate()
'実行
End Sub
とするのがよいのではないでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) excel vbaでselenium basic 3 2022/10/02 12:35
- Excel(エクセル) エクセルで、特定のセルの内容を更新すると、別の特定セルに 更新日付が自動的に表示させる方法はあります 1 2022/11/14 21:03
- その他(Microsoft Office) エクセルのマクロについて教えてください。 5 2023/01/21 09:39
- Visual Basic(VBA) エクセルのマクロについて教えてください。 1 2023/08/08 11:02
- Excel(エクセル) 【マクロ】webアドレスにて指定されたCSVファイル【excelソフト表示】を印刷する件 1 2023/02/15 01:52
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/07/10 09:06
- Visual Basic(VBA) vbaエクセルマクロについて あるデータを作成し、デスクトップに.xlsx形式で保存するマクロを作成 2 2023/03/02 18:54
- Excel(エクセル) エクセルのマクロについて教えてください。 1 2023/02/11 11:05
- Visual Basic(VBA) 列 A に同じ日が2つが必要です。 1 2023/03/28 07:25
- Visual Basic(VBA) vbaエクセルマクロについて あるデータを作成し、デスクトップに.xlsx形式で保存するマクロを作成 6 2023/03/03 18:05
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教えるわが家の防犯対策術!
ホームセキュリティのプロが、家庭の防犯対策を真剣に考える 2組のご夫婦へ実際の防犯対策術をご紹介!どうすれば家と家族を守れるのかを教えます!
-
エクセルで定期的(30分おき)にマクロを実行させる方法は?
Excel(エクセル)
-
エクセル時間毎ごとにマクロを実行するやり方。
Excel(エクセル)
-
「一定の時間間隔で5秒毎にMacro1を実行する」
Excel(エクセル)
-
-
4
エクセルnow関数自動更新
Excel(エクセル)
-
5
エクセルでVBAを使用して1分毎にファイルを保存するプログラムを書きた
Excel(エクセル)
-
6
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
7
エクセルのマクロを一定時間ごとに実行
Excel(エクセル)
-
8
エクセルで参照しているデータを常に最新の状態にしたい
Excel(エクセル)
-
9
マクロ 実行ボタンを押さずに常に実行
Excel(エクセル)
-
10
エクセルVBAにおけるON TIMEメソッドの解除方法について
Visual Basic(VBA)
-
11
毎日指定時刻に自動でエクセルを開き、マクロを起動する方法
Visual Basic(VBA)
-
12
Excelマクロにて、タイマーで自動更新は出来るのでしょうか?
Visual Basic(VBA)
-
13
Excel(エクセル) VBA プロシージャーをミリ秒で繰り返し実行する方法
Excel(エクセル)
-
14
現在時刻をリアルタイムで更新するには?
Excel(エクセル)
-
15
vba セルに入力した時間をマクロで受け取るには?
Excel(エクセル)
-
16
特定セルの内容を更新したら、その更新日を自動的に表示する方法について
Excel(エクセル)
-
17
EXCEL あるセルに数字が入力されれば既存マクロ実行させたい
Excel(エクセル)
-
18
VBA(エクセル)で自動的にボタンをクリックさせるには
その他(プログラミング・Web制作)
-
19
エクセルで5分ごとにデータを蓄積、保存したいのですが…
Excel(エクセル)
-
20
Excel 別ファイルに自動的に反映させたい
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで特定の列が0表示の場...
-
Excel マクロ VBA プロシー...
-
Excel・Word リサーチ機能を無...
-
メッセージボックスのOKボタ...
-
ExcelのVBA。public変数の値が...
-
一つのTeratermのマクロで複数...
-
特定のPCだけ動作しないVBAマク...
-
エクセルで別のセルにあるふり...
-
Excel VBAからAccessマクロを実...
-
ExcelVBAでPDFを閉じるソース
-
Excel2013 VBA マクロ実行中に...
-
エクセルに張り付けた写真のフ...
-
IF関数を使ってマクロを実行さ...
-
Excel 改ページのVBAうまくい...
-
エクセルのマクロについて教え...
-
ExcelVBA 図形をクリックした...
-
EXCELのVBAでRange("A1:C4")を...
-
Excelのマクロについて教えてく...
-
有効数字N桁のマクロについて
-
MSアクセスのマクロ・モジュー...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel・Word リサーチ機能を無...
-
特定のPCだけ動作しないVBAマク...
-
エクセルで特定の列が0表示の場...
-
Excel マクロ VBA プロシー...
-
メッセージボックスのOKボタ...
-
一つのTeratermのマクロで複数...
-
エクセルで別のセルにあるふり...
-
ExcelのVBA。public変数の値が...
-
エクセルに張り付けた写真のフ...
-
ExcelVBAでPDFを閉じるソース
-
EXCELのVBAでRange("A1:C4")を...
-
Excel VBAからAccessマクロを実...
-
TERA TERMを隠す方法
-
エクセルのマクロについて教え...
-
エクセルのマクロについて教え...
-
エクセルのマクロについて教え...
-
エクセルのマクロについて教え...
-
マクロ実行時、ユーザーフォー...
-
Excelのマクロについて教えてく...
-
ソース内の行末に\\
おすすめ情報