Delphi 生成excel中餅圖的實(shí)例代碼
更新時(shí)間:2013年08月19日 16:09:35 作者:
這篇文章介紹了Delphi 生成excel中餅圖的實(shí)例代碼,有需要的朋友可以參考一下
復(fù)制代碼 代碼如下:
var
i,j,m,n,count1:integer;
str:string;
Jdate:tdatetime;
channellist,potBstrtime,potEstrtime,Jchannelname:string;
Rres:boolean;
JSHR:double;
Excelid,achart1,cell1,cell2,cell3,cell4,cellMiddle,Range1,Range2,series1:variant;
ExRowsValue,ExRowsName,ExClos:Integer;
ImagePage,dataPage:integer;
leftPostion,topPostion,widthPostion,heightPostion:integer;
begin
//創(chuàng)建OLE對(duì)象
try
Excelid:=CreateOleObject( 'Excel.Application' );
except
on Exception do raise exception.Create('無(wú)法創(chuàng)建Xls文件,請(qǐng)確認(rèn)是否安裝EXCEL')
end;
Excelid.Visible := false; //Excel顯示設(shè)置
Excelid.WorkBooks.Add; //生成新的excel文件
//不用excel以前的頁(yè)
Excelid.worksheets.add;
dataPage:=Excelid.Worksheets.count; //用作數(shù)據(jù)頁(yè)
Excelid.worksheets.add;
ImagePage:=Excelid.Worksheets.count;
//showmessage(inttostr(dataPage));
//showmessage(inttostr(ImagePage)+'sdfg');
Jdate:=DateTimePicker1.Date;
count1:=0;
ExRowsValue:=1; //存儲(chǔ)值
ExRowsName:=2; //存儲(chǔ)名稱
//取得頻率編號(hào)
for i:=0 to CheckListBoxFQ.Items.Count-1 do
begin
if CheckListBoxFQ.Checked[i] then
begin
channellist:= QCaky.FChannelList[i]+','+channellist;
end;
end;
delete(channellist,length(channellist),1);
leftPostion:=20;
topPostion:=50;
widthPostion:=450;
heightPostion:=230;
for i:=0 to CheckListBoxPOTT.Items.Count-1 do
begin
if CheckListBoxPOTT.Checked[i] then
begin
//動(dòng)態(tài)生成excel頁(yè)數(shù)
//Excelid.worksheets.add;
//sheetCount:=sheetCount+1;
//Excelid.worksheets[sheetCount].name:='圖表頁(yè)'+inttostr(sheetCount);
//在這里生成圖表
if CheckListBoxPOTT.Items[i]='全天' then
begin
potBstrtime:='';
potEstrtime:='';
end
else
begin
potBstrtime:=QCaky.FPOTbeginList[i];
potEstrtime:=QCaky.FPOTendList[i];
end;
Rres:=QCaky.getFQShr(Jdate,FormMain.QAreacode,channellist,potBstrtime,potEstrtime); //取得占有率
ExClos:=1;
while not QCaky.FADOQueryFQ.Eof do
begin
Excelid.worksheets[dataPage].Activate;
Jchannelname:=QCaky.FADOQueryFQ.fieldbyname('channelname').AsString;
JSHR:=QCaky.FADOQueryFQ.fieldbyname('allshr').AsFloat;
Excelid.worksheets[dataPage].Cells[ExRowsName,ExClos].Value :=Jchannelname;
Excelid.worksheets[dataPage].Cells[ExRowsValue,ExClos].Value :=JSHR;
inc(ExClos);
QCaky.FADOQueryFQ.Next;
end;
{添加一個(gè)二維圖(20,50,450,230)表示(左,頂,寬,高)}
//achart1 := Excelid.worksheets[ImagePage].chartobjects.add(20,50,450,230);
achart1 := Excelid.worksheets[ImagePage].chartobjects.add(leftPostion,topPostion,widthPostion,heightPostion);
achart1.chart.charttype := xl3DPie ; //生成何種類型的圖********在此生成的是餅圖
//設(shè)置x軸、y軸數(shù)據(jù)
cell1 := Excelid.worksheets[dataPage].Cells[ExRowsName,1];
cell2 := Excelid.worksheets[dataPage].Cells[ExRowsName,ExClos];
cell3 := Excelid.worksheets[dataPage].Cells[ExRowsValue,1];
cell4 := Excelid.worksheets[dataPage].Cells[ExRowsValue,ExClos];
Range1 := Excelid.worksheets[dataPage].Range[cell1, cell2]; //設(shè)定Chart類別坐標(biāo)軸(x軸)的取值區(qū)域
Range2 := Excelid.worksheets[dataPage].Range[cell3, cell4]; //設(shè)定Chart數(shù)值坐標(biāo)軸(y軸)的取值區(qū)域
series1:= achart1.chart.seriescollection ;
//series1.add (Range2,xlColumns,false); //設(shè)置y軸的數(shù)據(jù)
series1.add (Range2,true); //可以使用,能夠生成餅圖
achart1.chart.seriescollection[1].name:='nihao';
//設(shè)置餅圖的形式
achart1.chart.seriescollection[1].ApplyDataLabels(xlDataLabelsShowLabelAndPercent,true,true,true);
achart1.Chart.Axes[xlCategory].CategoryNames := Range1; //設(shè)置x軸數(shù)據(jù)
//series1.add (Range2,xlColumns,false); //設(shè)置y軸的數(shù)據(jù)
//achart1.Chart.Axes[xlCategory].CategoryNames := Range1; //設(shè)置x軸數(shù)據(jù)
//刪除右側(cè)的標(biāo)題
achart1.Chart.Legend.delete;
//添加圖表標(biāo)題
achart1.Chart.HasTitle:=True;
achart1.Chart.ChartTitle.Characters.Text:='收視率走勢(shì)圖';
achart1.Chart.HasLegend:=true;
achart1.Chart.Legend.Position := xlBottom;
//圖表左標(biāo)說(shuō)明
//achart1.Chart.Axes(xlValue,xlPrimary).HasTitle := True;
//achart1.Chart.Axes(xlValue,xlPrimary).AxisTitle.Characters.Text := '收視率(%)';
//圖表下標(biāo)說(shuō)明
//achart1.Chart.Axes(xlCategory,xlPrimary).HasTitle:=True;
//achart1.Chart.Axes(xlCategory,xlPrimary).AxisTitle.Characters.Text:='時(shí)間';
ExRowsName:=ExRowsName+2;
ExRowsValue:=ExRowsValue+2;
end; //如果時(shí)段設(shè)置被選中
leftPostion:=20;
topPostion:=topPostion+600;
//showmessage(inttostr(dataPage));
end;
Excelid.Visible := true;
end;
相關(guān)文章
Delphi遠(yuǎn)程連接Mysql的實(shí)現(xiàn)方法
這篇文章主要介紹了Delphi遠(yuǎn)程連接Mysql的實(shí)現(xiàn)方法,需要的朋友可以參考下2014-09-09
delphi程序全屏顯示無(wú)標(biāo)題欄覆蓋整個(gè)屏幕(適合屏保)
delphi 簡(jiǎn)單實(shí)現(xiàn)程序全屏顯示無(wú)標(biāo)題欄,覆蓋整個(gè)屏幕,這個(gè)在做工控機(jī)或屏保時(shí)有用的,具體代碼如下,感興趣的朋友可以參考下哈2013-06-06
delphi實(shí)現(xiàn)將BMP格式圖形轉(zhuǎn)化為JPG格式圖形的方法
這篇文章主要介紹了delphi實(shí)現(xiàn)將BMP格式圖形轉(zhuǎn)化為JPG格式圖形的方法,通過(guò)簡(jiǎn)單的自定義函數(shù)調(diào)用系統(tǒng)自帶的changefileext及SaveToFile等方法來(lái)實(shí)現(xiàn)格式轉(zhuǎn)換功能,是非常實(shí)用的技巧,需要的朋友可以參考下2014-12-12
截取指定符號(hào)之間的字符串(隨機(jī)讀取)delphi實(shí)例代碼
這篇文章主要介紹了截取指定符號(hào)之間的字符串(隨機(jī)讀取)delphi實(shí)例代碼,有需要的朋友可以參考一下2013-12-12
springboot如何完美通過(guò)token獲取用戶信息
這篇文章主要給大家介紹了關(guān)于springboot如何完美通過(guò)token獲取用戶信息的相關(guān)資料, Token是在服務(wù)端產(chǎn)生的,如果前端使用用戶名/密碼向服務(wù)端請(qǐng)求認(rèn)證,服務(wù)端認(rèn)證成功,那么在服務(wù)端會(huì)返回Token給前端,需要的朋友可以參考下2023-12-12
Java中CountDownLatch和CyclicBarrier的區(qū)別與詳解
CountDownLatch和CyclicBarrier是Java并發(fā)包提供的兩個(gè)非常易用的線程同步工具類,本文主要介紹了Java中CountDownLatch和CyclicBarrier的區(qū)別與詳解,具有一定的參考價(jià)值,感興趣的可以了解一下2023-11-11
Delphi 中內(nèi)存映射對(duì)于大文件的使用
這篇文章主要介紹了Delphi 中內(nèi)存映射對(duì)于大文件的使用的相關(guān)資料,希望通過(guò)本文能幫助到大家,需要的朋友可以參考下2017-09-09

