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

如何更改sheet的名字呀?

尚未結案
piggy213
一般會員


發表:16
回覆:6
積分:4
註冊:2002-12-27

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-10-03 21:27:13 IP:203.67.xxx.xxx 未訂閱
以下程式的目的是 1.copy原有sheet內容新增幾個同樣的sheet 2.更改新增後的sheet名字
 procedure TForm1.Button1Click(Sender: TObject); 
 var ex,wb,ExSheet:Olevariant;  
 begin 
     ex := CreateOleObject('Excel.Application');                
     wb := ex.WorkBooks.Open('C:\Temp\8D.XLS',IgnoreReadOnlyRecommended:=True); 
     ex.visible := true; 
     ExSheet := wb.Sheets['PT'].Copy(After:=wb.Sheets['PT']);
     ExSheet.Name := 'SMK';
    ^^^^^^^^^^^^^^^^^^^^^^^此行會發生錯誤!!
 end; 
各位高手,可以幫我解答嗎? 謝謝!
timhuang
尊榮會員


發表:78
回覆:1815
積分:1608
註冊:2002-07-15

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-10-04 02:28:52 IP:61.62.xxx.xxx 未訂閱
Hi, 由於複製 sheet 的功能並不會傳回該新增的 sheet ole variant, 所以必須從新增的 sheet 相對於已知的 sheet 下手, 如你的範例中, 是 copy after 'PT' 這個 sheet, 所以可以利用    ExSheet := wb.Sheets[wb.Sheets['PT'].Index + 1];    來取得新增的 sheet 哦, 所以程式修改一下就行了:    
 procedure TForm1.Button1Click(Sender: TObject);
 var ex,wb,ExSheet:Olevariant;
 begin
     ex := CreateOleObject('Excel.Application');
     wb := ex.WorkBooks.Open('C:\Temp\8D.XLS',IgnoreReadOnlyRecommended:=True);     
     ex.visible := true;
     wb.Sheets['PT'].Copy(After:=wb.Sheets['PT']);
     //ExSheet.Name := 'SMK';
     ExSheet := wb.Sheets[wb.Sheets['PT'].Index + 1];
     ExSheet.Name := 'SMK';     end;
系統時間:2024-07-01 3:26:35
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!