如何更改sheet的名字呀? |
尚未結案
|
piggy213
一般會員 ![]() ![]() 發表:16 回覆:6 積分:4 註冊:2002-12-27 發送簡訊給我 |
以下程式的目的是
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 發送簡訊給我 |
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; |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |