' DDE 資料紀錄問題
Option Explicit
Dim actEnabled As Boolean
Dim cIndex As Single
Private Sub Workbook_Open()
' 以下四列資料之設定,可配合實作、或測試之目的,直接在 "sheet1" 指定之設定欄,得隨時予以異動。
If (Sheets("sheet1").Range("BA1").Value = "") Then Sheets("sheet1").Range("BA1").Value = "08:45:00" ' 假設C6欄位為空白,則寫入開盤起始時間
If (Sheets("sheet1").Range("BA2").Value = "") Then Sheets("sheet1").Range("BA2").Value = "13:45:59" ' D6欄位亦同。(此兩欄紀錄起始終止時間)
If (Sheets("sheet1").Range("BB1").Value = "") Then Sheets("sheet1").Range("BB1").Value = "00:01:00" ' 紀錄資料匯入相隔時間,如每隔一分鐘寫入一次。
If (Sheets("sheet1").Range("BB2").Value = "") Then Sheets("sheet1").Range("BB2").Value = 0 ' 紀錄已匯入資料列數。
If (TimeValue(Now) > Sheets("sheet1").Range("BA2").Value) Then ' 如果目前時間業已超過 D6 的營業時段,則呼叫.......
Call stopProcedure
Else ' 反之在 D6 設定時間以前,則呼叫.......
Call startProcedure
End If
End Sub
Private Sub Workbook_BeforeClose(Cancel As Boolean)
On Error Resume Next
Call actStop
End Sub
Sub startProcedure() ' 保留作為控制項之應用程序,如按鈕之巨集應用等。
Call actStart
End Sub
Sub stopProcedure() ' 保留作為控制項之應用程序,如按鈕之巨集應用等。
Call actStop
End Sub
Sub newTitle()
Sheets(2).[A1].Resize(, 4) = Sheets(1).[A1:D1].Value ' 套上你欲匯入資料的表頭名稱
End Sub
Sub Starter()
If (actEnabled = True And TimeValue(Now) >= Sheets("sheet1").Range("BA1").Value And TimeValue(Now) <= Sheets("sheet1").Range("BA2").Value) Then
cIndex = Sheets("sheet1").Range("BB2").Value
If (cIndex = 0) Then Call newTitle ' newTitle 程序 (由使用者自行定義) 是將第一列的資料抬頭名稱寫入到sheet2;如日期、時間的對應欄位資料等。