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

匯出多個StringGrid到Excel(OLE)

尚未結案
RemycinLu
一般會員


發表:34
回覆:20
積分:10
註冊:2003-10-02

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-07-30 17:16:05 IP:66.144.xxx.xxx 未訂閱
http://delphi.ktop.com.tw/topic.php?TOPIC_ID=53818 這篇已經可以把1個StringGrid的資料存到Excel第1個Sheet裡面,假如我現在有3個StringGrid的資料要存到Excel第1,2,3個Sheet裡面,那要怎麼修改?謝謝
RaynorPao
版主


發表:139
回覆:3622
積分:7025
註冊:2002-08-12

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-07-30 17:27:04 IP:203.73.xxx.xxx 未訂閱
引言: http://delphi.ktop.com.tw/topic.php?TOPIC_ID=53818 這篇已經可以把1個StringGrid的資料存到Excel第1個Sheet裡面,假如我現在有3個StringGrid的資料要存到Excel第1,2,3個Sheet裡面,那要怎麼修改?謝謝 < face="Verdana, Arial, Helvetica"> RemycinLu 你好: 試試把原本迴圈的部分,改成以下這個樣子,行不行呢? < class="code"> //...以上省略... ExcelSheets=ExcelBook.OlePropertyGet("Worksheets"); for(int k=0; k<3; k++) { TStringGrid *SG=NULL; SG=dynamic_cast(FindComponent("StringGrid"+IntToStr(k+1))); if(SG) { ExcelSheet=ExcelSheets.OlePropertyGet("Item", k+1); for(int i=0; iColCount; i++) { for(int j=0; jRowCount; j++) { AnsiString szCol; AnsiString szRow; int m=i/COL_CYCLE-1; int n=i%COL_CYCLE; szCol=(m<0)? (AnsiString)szColCycle[n]: (AnsiString)szColCycle[m]+(AnsiString)szColCycle[n]; szRow=(IntToStr)(j+1); ExcelRange=ExcelSheet.OlePropertyGet("Range", StringToOleStr(szCol+szRow)); ExcelRange.OlePropertySet("Value", StringToOleStr(SG->Cells[i][j])); Application->ProcessMessages(); } } } } AnsiString szXlsFile=ExtractFilePath(Application->ExeName)+"test1.xls"; //...以下省略... -- Enjoy Researching & Developing --
------
-- 若您已經得到滿意的答覆,請適時結案!! --
-- 欲知前世因,今生受者是;欲知來世果,今生做者是 --
-- 一切有為法,如夢幻泡影,如露亦如電,應作如是觀 --
系統時間:2024-04-29 11:04:09
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!