全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:672
推到 Plurk!
推到 Facebook!

當Excel中的欄位持續更新的問題

尚未結案
YAUYAU
一般會員


發表:38
回覆:26
積分:12
註冊:2003-09-25

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-07-09 22:58:59 IP:140.122.xxx.xxx 未訂閱
在更新檢查中,假如Excel A7中的欄位持續更動,程式即會發生錯誤,不知道是我的Timer設定錯誤還是程式的錯誤... 附上我的source code,希望前輩給予一些指點,謝謝~~    //---------------------------------------------------------------------------    #include  #include #pragma hdrstop #include #include "Unit1.h" //--------------------------------------------------------------------------- #pragma package(smart_init) #pragma link "Excel_2K_SRVR" #pragma resource "*.dfm" TForm1 *Form1; int is_odd; //--------------------------------------------------------------------------- __fastcall TForm1::TForm1(TComponent* Owner) : TForm(Owner) { } //--------------------------------------------------------------------------- void __fastcall TForm1::Exit_Click(TObject *Sender) { Form1->Close(); } //--------------------------------------------------------------------------- void __fastcall TForm1::Open_Excel_Click(TObject *Sender) { WideString aa; if (OpenDialog1->Execute()) { aa=OpenDialog1->FileName; ExcelApplication1->Connect(); ExcelApplication1->Workbooks->Open(aa); ExcelWorkbook1->ConnectTo(ExcelApplication1->get_ActiveWorkbook()); ExcelApplication1->set_Visible(0,true); ExcelWorksheet1->ConnectTo(ExcelWorkbook1->get_ActiveSheet()); } delete aa ; } //--------------------------------------------------------------------------- void __fastcall TForm1::FormCreate(TObject *Sender) { Edit1->Text=""; Edit2->Text=""; } //--------------------------------------------------------------------------- void __fastcall TForm1::Exec_Click(TObject *Sender) { Timer1->Interval=8000; is_odd=1; } //--------------------------------------------------------------------------- void __fastcall TForm1::Timer1Timer(TObject *Sender) { if(is_odd == 1 ) { int l,h,r1,r2,r3; Variant v1_7(7),v1_8(8),v1_9(9); Variant v1(1); Variant vr1,vr2,vr3; r1=StrToInt(VarToStr(vr1=ExcelWorksheet1->Cells->get__Default(v1_7,v1))); //r2=StrToInt(VarToStr(vr2=ExcelWorksheet1->Cells->get__Default(v1_8,v1))); //r3=StrToInt(VarToStr(vr3=ExcelWorksheet1->Cells->get__Default(v1_9,v1))); h=StrToInt(Edit1->Text); l=StrToInt(Edit2->Text); if (r1l) { return ; } else { OleContainer1->DoVerb(0); } } }
YAUYAU
一般會員


發表:38
回覆:26
積分:12
註冊:2003-09-25

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-07-13 13:42:53 IP:140.122.xxx.xxx 未訂閱
附上原始程式: ftp://guest:guest@140.122.77.204/FTP/4.rar BCB6.0寫的..
YAUYAU
一般會員


發表:38
回覆:26
積分:12
註冊:2003-09-25

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-07-18 19:29:21 IP:140.122.xxx.xxx 未訂閱
問題已解決,我是直接使用 ExcelWorksheet 的 OnChange 事件,就不需要利用 Timer 作檢查了~~
系統時間:2024-05-15 0:06:18
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!