ifix和excel連接上課講義_第1頁
ifix和excel連接上課講義_第2頁
ifix和excel連接上課講義_第3頁
ifix和excel連接上課講義_第4頁
ifix和excel連接上課講義_第5頁
已閱讀5頁,還剩2頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)

文檔簡介

1、Good is good, but better carries it.精益求精,善益求善。ifix和excel連接IFIX與EXCEL的連接2007-02-2420:16:44作者:HYPERLINK/member/member.php?username=ifixonlinet_blankifixonline來源:HYPERLINKt_blank杭州集益科技有限公司文字大?。骸綡YPERLINKjavascript:fontZoom(16)大】【HYPERLINKjavascript:fontZoom(14)中】【HYPERLINKjavascript:fontZoom(12)小】評分等級:

2、0HYPERLINK/misc.php?action=viewratings&tid=85&pid=553o評分0第一步,創(chuàng)建ODBC數(shù)據(jù)源,具體方法:啟動控制面板中的數(shù)據(jù)源ODBC,單擊“系統(tǒng)DNS”對話框,選擇所需數(shù)據(jù)源的驅(qū)動,如:“Microsoftexceldriver(*.exl)”,單擊“完成”按鈕,彈出“ODBCMicrosoftexcel安裝”對話框;在數(shù)據(jù)源名中定義一個數(shù)據(jù)源名稱,數(shù)據(jù)庫中“選擇”中選擇區(qū)縣數(shù)據(jù)所在的數(shù)據(jù)庫,此數(shù)據(jù)庫的表至少有三個字段:時間字段、數(shù)據(jù)字段、毫秒字段。單擊確定按鈕,新創(chuàng)建數(shù)據(jù)源就添加到“系統(tǒng)DNS”列表中。第二步,在IFIX中創(chuàng)建代碼ADO在安裝

3、了MCROWINBASIC6.0等軟件就有了;PrivateSubCommandButton1_Click()注釋:1。該程序需要安裝ADO2.0目標(biāo)庫并在本機注冊2。MicrosoftActiveXDataObjects2.1Library必須被引用(Office2000)3。MicrosoftExcel9.0objectlibraries必須被引用(Office2000)4。劃=處可根據(jù)具體報表修改DimstrQueryAvgAsStringDimcAsIntegerDimrAsIntegerDimIntyexcelAsExcel.ApplicationDimMyDate,MyMonth,

4、MyDay,MyHour,MyMinute,MySecondDimStartTime,EndTime,Duration,DisplayDay,DisplayMonthAsString+=報表中的TAGDimTag1,Tag2,Tag3,Tag4,Tag5,Tag6,Tag7,Tag8AsStringDimItemsAsIntegerTag1=TESTTag2=TEST1Tag3=Tag4=Tag5=Tag6=Tag7=Tag8=從歷史庫中取得域項,2-DATATIME,VALUE,TAG共三項Items=2-=MyDate=Now()MyMonth=Month(MyDate)MyDay=Day

5、(MyDate)MyHour=Hour(MyDate)MyMinute=Minute(MyDate)MySecond=Second(MyDate)StartTime=2000&-&MyMonth&-&MyDay-1&00:00:00EndTime=2000&-&MyMonth&-&MyDay-1&23:00:00+=查詢,根據(jù)報表修改strQueryAvg=SelectDATETIME,VALUE,TAGFROMFIX&_WHEREMODE=AVERAGEand(TAG=&Tag1&orTAG=&Tag2&_orTAG=&Tag3&orTAG=&Tag4&orTAG=&Tag5&_orTAG=

6、&Tag6&orTAG=&Tag7&orTAG=&Tag8&)&_andINTERVAL=01:00:00and&_(DATETIME=and&_DATETIME=)-=DimcnADOAsNewADODB.ConnectionDimrsADOAsRecordsetSetcnADO=NewADODB.ConnectioncnADO.ConnectionString=DSN=FIXDynamicsHistoricalData;UID=sa;PWD=;cnADO.OpenFIXDynamicsHistoricalData,sa,SetrsADO=NewADODB.RecordsetrsADO.Op

7、enstrQueryAvg,cnADO,adOpenForwardOnly,adLockBatchOptimistic如果執(zhí)行上面的語句出錯的話,則最大的可能性就是SQL語句有錯誤!r=1SetIntyexcel=NewExcel.ApplicationIntyexcel.Visible=False+=打開的報表文件名DimOutReportFileAsStringDimInReportFileAsStringInReportFile=C:DynamicsAppHIST1Intyexcel.Workbooks.OpenInReportFile&.XLSIntyexcel.Sheets(Shee

8、t2).SelectIntyexcel.Columns(A:Z).SelectIntyexcel.Selection.ClearContentsIntyexcel.Range(A1).SelectWhilersADO.EOFTrueWithIntyexcel.Worksheets(2)Forc=0ToItemsIfrsADO(c)Then.Cells(r,c+1).Value=rsADO(c)Nextcr=r+1rsADO.MoveNextEndWithWendIntyexcel.Sheets(Sheet1).SelectIntyexcel.ActiveSheet.PageSetup.Orie

9、ntation=xlPortraitxlLandscapeIntyexcel.ActiveSheet.PageSetup.PaperSize=xlPaperA4Intyexcel.ActiveSheet.PrintOutIntyexcel.DisplayAlerts=FalseIntyexcel.ActiveWorkbook.SaveOutReportFile=InReportFile&_00&MyMonth&MyDayIntyexcel.ActiveWorkbook.SaveAsOutReportFileIntyexcel.QuitIntyexcel.DisplayAlerts=TrueSe

10、tIntyexcel=NothingSetcnADO=NothingEndSub4.2iFIX中電廠日報表的生成總則:運用iFIX的調(diào)度器運行基于時間的VBA腳本來生成每天的EXCEL格式日報表。1)iFIX中調(diào)度設(shè)置在iFIX中新建時間調(diào)度,設(shè)置成間隔1小時的調(diào)度項,然后點擊VB編輯器自定義腳本.2)初始變量定義DimReportArrayAsVariantRem存放日報中所有要顯示的參數(shù)的數(shù)組DimFirstPoint1AsVariantRem第一個變量DimtempvarAsVariantRem中間變量DimstrStartTime,strEndTimeRem報表查詢的時間范圍DimIn

11、tervalAsVariantRem報表查詢的間隔時間DimOutReportfileAsVariantRem輸出EXCEL表格的文件名DimTemplateNameAsStringRem這個是日報表模板的文件名3)建立對EXCEL的引用,并打開報表的模板文件:SetmsExcel=CreateObject(Excel.Application)WithmsExcel.WindowState=xlMinimized.Visible=False.Workbooks.OpenReportTemplateName,FalseRem打開報表的模板文件.ActiveWorkbook.ActiveSheet

12、.Select.DisplayAlerts=False.DisplayAlerts=False.Wait(Now()+0.00002)EndWith4)創(chuàng)建SQL查詢語句:DimrsADOAsNewADODB.RecordsetDimcnADOAsNewADODB.ConnectionDimSQL0,SQL1ASStringSQLO=selectFIX.valuefromFIXwhereFIX.interval=|+Interval+|andFIX.datetime=ts|+strStartTime+|andFIX.datetimets|+strEndTime+|RemFIX為本地節(jié)點名SQL

13、1=SQLO&and(FIX.tag=|&FirstPoint1&|iTotalCols=1ForEachtempvarInFirstReportPointsiTotalCols=iTotalCols+1SQL1=SQL1&orFIX.tag=|&tempvar&|NexttempvarSQL1=SQL1+)5)執(zhí)行對數(shù)據(jù)庫的查詢:SetcnADO=NewADODB.ConnectionWithcnADORem.CursorLocation=adUseClient.OpenPROVIDER=MicrosoftOLEDBProviderforODBCDrivers;dsn=FIXDynamics

14、HistoricalData;uid=sa;pwd=;.Execute(SQL1)EndWith6)建立查詢數(shù)據(jù)庫后的記錄集,并把數(shù)據(jù)寫到EXCEL中后另存為EXCEL文件:SetrsADO=NewADODB.RecordsetrsADO.CursorLocation=adUseClientrsADO.OpenSQL1,cnADO,adOpenForwardOnly,adLockReadOnlyIfrsADO.BOFThenrsADO.ClosecnADO.CloseWithmsExcelDoEvents.ActiveWorkbook.Close.QuitEndWithSetmsExcel=NothingRemMsgBox第一個表查詢條件為空,請檢查查詢條件ExitSubElsec=1WhilersADO.EOFTrueWithmsExcel.Worksheets(1)Forj=1To24IfrsADO(0)ThenmsExcel.Works

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論