怎么样读取Excel第三行,第二列的数据?sy:=ExcelApp.Cells(3, 2);不行 怎么样读取Excel第三行,第二列的数据?这样不行呀~sy:=ExcelApp.Cells(3, 2);不行 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 不知道是不是EXCEL的版本问题我曾经做过WORD的表格,在Word2000和Word2003中表格单元的访问就不一致。 我用过一次2000是,R1C1为第一行第一列 R3C2应该是第二列吧,实验一下 吧:) excelworksheet1.Cells.Item[3,2].FormulaR1C1这是你想要的 sy:=ExcelApp.Cells[3, 2].value;这个对了~! use ComObj,Excel97全面控制 Excelvar eclApp,WorkBook:Variant; try eclApp:=CreateOleObject('Excel.Application'); WorkBook:=CreateOleobject('Excel.Sheet'); except MessageBox(Handle,'您的机器里未安装Microsoft Excel!','错误',MB_OK+MB_ICONERROR); Exit; end; try if FileExists(SaveDialog1.FileName) then WorkBook:=eclApp.WorkBooks.Open(SaveDialog1.FileName) else WorkBook:=eclApp.WorkBooks.add; finally WorkBook.Close; eclApp.Quit; eclApp:=UnAssigned; end;首先创建 Excel 对象,使用ComObj:var ExcelID: Variant;ExcelID := CreateOleObject( 'Excel.Application' );1) 显示当前窗口:ExcelID.Visible := True;2) 更改 Excel 标题栏:ExcelID.Caption := '应用程序调用 Microsoft Excel';3) 添加新工作簿:ExcelID.WorkBooks.Add;4) 打开已存在的工作簿:ExcelID.WorkBooks.Open( 'C:\Excel\Demo.xls' );5) 设置第2个工作表为活动工作表:ExcelID.WorkSheets[2].Activate; 或 ExcelID.WorkSheets['Sheet2'].Activate;6) 给单元格赋值:ExcelID.Cells[1,4].Value := '第一行第四列';7) 设置指定列的宽度(单位:字符个数),以第一列为例:ExcelID.ActiveSheet.Columns[1].ColumnWidth := 5;8) 设置指定行的高度(单位:磅)(1磅=0.035厘米),以第二行为例:ExcelID.ActiveSheet.Rows[2].RowHeight := 1/0.035; // 1厘米9) 在第8行之前插入分页符:ExcelID.WorkSheets[1].Rows[8].PageBreak := 1;10) 在第8列之前删除分页符:ExcelID.ActiveSheet.Columns[4].PageBreak := 0;11) 指定边框线宽度:ExcelID.ActiveSheet.Range[ 'B3:D4' ].Borders[2].Weight := 3;1-左 2-右 3-顶 4-底 5-斜( \ ) 6-斜( / )12) 清除第一行第四列单元格公式:ExcelID.ActiveSheet.Cells[1,4].ClearContents;13) 设置第一行字体属性:ExcelID.ActiveSheet.Rows[1].Font.Name := '隶书';ExcelID.ActiveSheet.Rows[1].Font.Color := clBlue;ExcelID.ActiveSheet.Rows[1].Font.Bold := True;ExcelID.ActiveSheet.Rows[1].Font.UnderLine := True;14) 进行页面设置:a.页眉:ExcelID.ActiveSheet.PageSetup.CenterHeader := '报表演示';b.页脚:ExcelID.ActiveSheet.PageSetup.CenterFooter := '第&P页';c.页眉到顶端边距2cm:ExcelID.ActiveSheet.PageSetup.HeaderMargin := 2/0.035;d.页脚到底端边距3cm:ExcelID.ActiveSheet.PageSetup.HeaderMargin := 3/0.035;e.顶边距2cm:ExcelID.ActiveSheet.PageSetup.TopMargin := 2/0.035;f.底边距2cm:ExcelID.ActiveSheet.PageSetup.BottomMargin := 2/0.035;g.左边距2cm:ExcelID.ActiveSheet.PageSetup.LeftMargin := 2/0.035;h.右边距2cm:ExcelID.ActiveSheet.PageSetup.RightMargin := 2/0.035;i.页面水平居中:ExcelID.ActiveSheet.PageSetup.CenterHorizontally := 2/0.035;j.页面垂直居中:ExcelID.ActiveSheet.PageSetup.CenterVertically := 2/0.035;k.打印单元格网线:ExcelID.ActiveSheet.PageSetup.PrintGridLines := True;15) 拷贝操作:a.拷贝整个工作表:ExcelID.ActiveSheet.Used.Range.Copy;b.拷贝指定区域:ExcelID.ActiveSheet.Range[ 'A1:E2' ].Copy;c.从A1位置开始粘贴:ExcelID.ActiveSheet.Range.[ 'A1' ].PasteSpecial;d.从文件尾部开始粘贴:ExcelID.ActiveSheet.Range.PasteSpecial;16) 插入一行或一列:a. ExcelID.ActiveSheet.Rows[2].Insert;b. ExcelID.ActiveSheet.Columns[1].Insert; 17) 删除一行或一列:a. ExcelID.ActiveSheet.Rows[2].Delete;b. ExcelID.ActiveSheet.Columns[1].Delete;18) 打印预览工作表:ExcelID.ActiveSheet.PrintPreview;19) 打印输出工作表:ExcelID.ActiveSheet.PrintOut;20) 工作表保存:if not ExcelID.ActiveWorkBook.Saved thenExcelID.ActiveSheet.PrintPreview;21) 工作表另存为:ExcelID.ActiveWorkBook.SaveAs( 'C:\Excel\Demo1.xls' );22) 放弃存盘:ExcelID.ActiveWorkBook.Saved := True;23) 关闭工作簿:ExcelID.WorkBooks.Close;24) 退出 Excel:ExcelID.Quit;使用Delphi 控制Excle二维图 在form中分别放入ExcelApplication, ExcelWorkbook和ExcelWorksheet var asheet1,achart, range:variant; 1)选择当第一个工作薄第一个工作表 asheet1:=ExcelApplication1.Workbooks[1].Worksheets[1]; 2)增加一个二维图 achart:=asheet1.chartobjects.add(100,100,200,200); 3)选择二维图的形态 achart.chart.charttype:=4; 4)给二维图赋值 series:=achart.chart.seriescollection; range:=sheet1!r2c3:r3c9; series.add(range,true); 5)加上二维图的标题 achart.Chart.HasTitle:=True; achart.Chart.ChartTitle.Characters.Text:=' Excle二维图' 6)改变二维图的标题字体大小 achart.Chart.ChartTitle.Font.size:=6; 7)给二维图加下标说明 achart.Chart.Axes(xlCategory, xlPrimary).HasTitle := True; achart.Chart.Axes(xlCategory, xlPrimary).AxisTitle.Characters.Text := '下标说明'; 8)给二维图加左标说明 achart.Chart.Axes(xlvalues, xlPrimary).HasTitle := True; achart.Chart.Axes(xlvalues, xlPrimary).AxisTitle.Characters.Text := '左标说明'; 9)给二维图加右标说明 achart.Chart.Axes(xlvalues, xlSecondary).HasTitle := True; achart.Chart.Axes(xlvalues, xlSecondary).AxisTitle.Characters.Text := '右标说明'; 10)改变二维图的显示区大小 achart.Chart.PlotArea.Left := 5; achart.Chart.PlotArea.Width := 223; achart.Chart.PlotArea.Height := 108; 11)给二维图坐标轴加上说明 achart.chart.seriescollection[1].NAME:='坐标轴说明'; _____________________________________________________________________procedure TForm1.Button5Click(Sender: TObject);varExcelApp,MyWorkBook,mysheet:Variant;i :byte;s: string;begintryExcelApp:=CreateOleObject('Excel.Application');MyWorkBook:=CreateOleobject('Excel.Sheet');//? MyWorkBook:=ExcelApp.workbooks.open('C:\Book1.xls');excepton Exception do raise exception.Create('无法打开Xls文件,请确认已 经安装EXCEL')end;ExcelApp.Visible := true;//? mysheet:=MyWorkBook.WorkSheets[1].name;MyworkBook:=ExcelApp.workBooks.Add;//在此处插入读数据库及写Excel文档的代码//其中写Excel文档的关键语句如下:Myworkbook.worksheets[1].range['A1:D1'].Merge(True);Myworkbook.worksheets[1].range['A1:D2'].HorizontalAlignment := $FFFFEFF4;MyWorkBook.WorkSheets[1].Cells[1,1].Value := 'YourTitle';i := 2;MyWorkBook.WorkSheets[1].Cells[i,1].Value := 'yourCaption1';MyWorkBook.WorkSheets[1].Cells[i,2].Value := 'yourCaption2';MyWorkBook.WorkSheets[1].Cells[i,3].Value := 'yourCaption3';MyWorkBook.WorkSheets[1].Cells[i,4].Value := 'yourCaption4';Myworkbook.worksheets[1].Range['A1:D2'].Font.Color := clBlue;Myworkbook.worksheets[1].Range['A1:D1'].Font.Name := '隶书';Myworkbook.worksheets[1].Range['A1:D1'].Font.Size := 18;i := 3;table1.close;table1.open;table1.First;while not table1.eof do beginMyWorkBook.WorkSheets[1].Cells[i,1].Value := table1.FieldByName('au_id').AsString;MyWorkBook.WorkSheets[1].Cells[i,2].Value := table1.FieldByName('royaltyper').AsInteger;MyWorkBook.WorkSheets[1].Cells[i,3].Value := table1.FieldByName('au_ord').AsInteger;MyWorkBook.WorkSheets[1].Cells[i,4].Value := table1.FieldByName('title_id').AsString;Inc(i);table1.Nextend;ExcelApp.Visible := true;s := 'A3:D'+ IntToStr(i-1);//设定字体. 栏宽等s := 'A1:D'+ IntToStr(i-1);Myworkbook.worksheets[1].Columns[1].ColumnWidth := 20;Myworkbook.worksheets[1].Columns[4].ColumnWidth := 25;Myworkbook.worksheets[1].Rows[1].RowHeight := 50;Myworkbook.worksheets[1].Rows[1].VerticalAlignment := $FFFFEFF4;Myworkbook.worksheets[1].Range[s].Font.Name := '仿宋';s := 'A2:D'+ IntToStr(i-1);Myworkbook.worksheets[1].Range[s].Borders.LineStyle := 1;//页面设置MyworkBook.WorkSheets[1].PageSetup.CenterHorizontally := true;Myworkbook.worksheets[1].pagesetup.PrintTitleRows := 'A1';//不能设置 papersize 属性, 原因不明//MyworkBook.WorkSheets[1].PageSetup.PaperSize := $9;tryMyWorkBook.saveas('c:\' + Edit1.Text + '.xls');MyWorkBook.close;except //当存为一个已有的文档而又不覆盖时将MyWorkBook.close; //产生一个例外end;ExcelApp.Quit;ExcelApp:=Unassigned; //释放VARIANT变量//设置字体 eclApp.ActiveSheet.Rows[NowRow].Font.Name := TitleEdt.Font.Name; eclApp.ActiveSheet.Rows[NowRow].Font.Color := TitleEdt.Font.Color; eclApp.ActiveSheet.Rows[NowRow].Font.Size:=TitleEdt.Font.Size; if fsBold in TitleEdt.Font.Style then eclApp.ActiveSheet.Rows[NowRow].Font.Bold:=true else eclApp.ActiveSheet.Rows[NowRow].Font.Bold:=false; if fsUnderLine in TitleEdt.Font.Style then eclApp.ActiveSheet.Rows[NowRow].Font.UnderLine := True else eclApp.ActiveSheet.Rows[NowRow].Font.UnderLine := false; if fsItalic in TitleEdt.Font.Style then eclApp.ActiveSheet.Rows[NowRow].Font.Italic:=true else eclApp.ActiveSheet.Rows[NowRow].Font.Italic:=false; eclApp.ActiveSheet.Rows[NowRow].HorizontalAlignment:=xlCenter;//合并单元格 WorkBook.worksheets[1].range['A'+inttostr(NowRow)+':'+Chr(64+ClassSetupADOQry.FieldByName('列数').AsInteger*2)+inttostr(NowRow)].Merge(True); eclApp.ActiveSheet.Rows[NowRow].RowHeight:=strtoint(TitleRowHeightEdt.Text); fastreport iff语句报错 delphi 日期转化 数据库Access violation 问题,实在是搞不明白,快被它搞疯了。 listbox1到listbox25一次过改变多个属性 报表打印 怪了!,我想每页打印5条记录,但第一页显示10条,其它显示5条。请高手解答 有没有类似strtoint的函数?可以将string转变为longint?在线等,急! 这份申请书怎么写! 【关注有分】一个谜语及寻求讲解Vxd制作的书籍 如何响应POP3协议的RETR n 命令???在线等待 5.1节日来临,GMAIL的50份邀请函剩余,送大家 判断密码是否正确时,始终出错,马上结贴
我曾经做过WORD的表格,在Word2000和Word2003中表格单元的访问就不一致。
R3C2应该是第二列吧,实验一下 吧:)
全面控制 Excel
var eclApp,WorkBook:Variant;
try
eclApp:=CreateOleObject('Excel.Application');
WorkBook:=CreateOleobject('Excel.Sheet');
except
MessageBox(Handle,'您的机器里未安装Microsoft Excel!','错误',MB_OK+MB_ICONERROR);
Exit;
end;
try
if FileExists(SaveDialog1.FileName)
then WorkBook:=eclApp.WorkBooks.Open(SaveDialog1.FileName)
else WorkBook:=eclApp.WorkBooks.add;
finally
WorkBook.Close;
eclApp.Quit;
eclApp:=UnAssigned;
end;首先创建 Excel 对象,使用ComObj:
var ExcelID: Variant;ExcelID := CreateOleObject( 'Excel.Application' );
1) 显示当前窗口:
ExcelID.Visible := True;2) 更改 Excel 标题栏:
ExcelID.Caption := '应用程序调用 Microsoft Excel';3) 添加新工作簿:
ExcelID.WorkBooks.Add;4) 打开已存在的工作簿:
ExcelID.WorkBooks.Open( 'C:\Excel\Demo.xls' );5) 设置第2个工作表为活动工作表:
ExcelID.WorkSheets[2].Activate;
或
ExcelID.WorkSheets['Sheet2'].Activate;6) 给单元格赋值:
ExcelID.Cells[1,4].Value := '第一行第四列';7) 设置指定列的宽度(单位:字符个数),以第一列为例:
ExcelID.ActiveSheet.Columns[1].ColumnWidth := 5;8) 设置指定行的高度(单位:磅)(1磅=0.035厘米),以第二行为例:
ExcelID.ActiveSheet.Rows[2].RowHeight := 1/0.035; // 1厘米9) 在第8行之前插入分页符:
ExcelID.WorkSheets[1].Rows[8].PageBreak := 1;10) 在第8列之前删除分页符:
ExcelID.ActiveSheet.Columns[4].PageBreak := 0;11) 指定边框线宽度:
ExcelID.ActiveSheet.Range[ 'B3:D4' ].Borders[2].Weight := 3;1-左 2-右 3-顶 4-底 5-斜( \ ) 6-斜( / )12) 清除第一行第四列单元格公式:
ExcelID.ActiveSheet.Cells[1,4].ClearContents;13) 设置第一行字体属性:
ExcelID.ActiveSheet.Rows[1].Font.Name := '隶书';
ExcelID.ActiveSheet.Rows[1].Font.Color := clBlue;
ExcelID.ActiveSheet.Rows[1].Font.Bold := True;
ExcelID.ActiveSheet.Rows[1].Font.UnderLine := True;14) 进行页面设置:a.页眉:
ExcelID.ActiveSheet.PageSetup.CenterHeader := '报表演示';
b.页脚:
ExcelID.ActiveSheet.PageSetup.CenterFooter := '第&P页';
c.页眉到顶端边距2cm:
ExcelID.ActiveSheet.PageSetup.HeaderMargin := 2/0.035;
d.页脚到底端边距3cm:
ExcelID.ActiveSheet.PageSetup.HeaderMargin := 3/0.035;
e.顶边距2cm:
ExcelID.ActiveSheet.PageSetup.TopMargin := 2/0.035;
f.底边距2cm:
ExcelID.ActiveSheet.PageSetup.BottomMargin := 2/0.035;
g.左边距2cm:
ExcelID.ActiveSheet.PageSetup.LeftMargin := 2/0.035;
h.右边距2cm:
ExcelID.ActiveSheet.PageSetup.RightMargin := 2/0.035;
i.页面水平居中:
ExcelID.ActiveSheet.PageSetup.CenterHorizontally := 2/0.035;
j.页面垂直居中:
ExcelID.ActiveSheet.PageSetup.CenterVertically := 2/0.035;
k.打印单元格网线:
ExcelID.ActiveSheet.PageSetup.PrintGridLines := True;15) 拷贝操作:a.拷贝整个工作表:
ExcelID.ActiveSheet.Used.Range.Copy;
b.拷贝指定区域:
ExcelID.ActiveSheet.Range[ 'A1:E2' ].Copy;
c.从A1位置开始粘贴:
ExcelID.ActiveSheet.Range.[ 'A1' ].PasteSpecial;
d.从文件尾部开始粘贴:
ExcelID.ActiveSheet.Range.PasteSpecial;16) 插入一行或一列:a. ExcelID.ActiveSheet.Rows[2].Insert;
b. ExcelID.ActiveSheet.Columns[1].Insert;
b. ExcelID.ActiveSheet.Columns[1].Delete;18) 打印预览工作表:
ExcelID.ActiveSheet.PrintPreview;19) 打印输出工作表:
ExcelID.ActiveSheet.PrintOut;20) 工作表保存:
if not ExcelID.ActiveWorkBook.Saved then
ExcelID.ActiveSheet.PrintPreview;21) 工作表另存为:
ExcelID.ActiveWorkBook.SaveAs( 'C:\Excel\Demo1.xls' );22) 放弃存盘:
ExcelID.ActiveWorkBook.Saved := True;23) 关闭工作簿:
ExcelID.WorkBooks.Close;24) 退出 Excel:
ExcelID.Quit;使用Delphi 控制Excle二维图
在form中分别放入ExcelApplication, ExcelWorkbook和ExcelWorksheet
var asheet1,achart, range:variant; 1)选择当第一个工作薄第一个工作表
asheet1:=ExcelApplication1.Workbooks[1].Worksheets[1]; 2)增加一个二维图
achart:=asheet1.chartobjects.add(100,100,200,200); 3)选择二维图的形态
achart.chart.charttype:=4; 4)给二维图赋值
series:=achart.chart.seriescollection;
range:=sheet1!r2c3:r3c9;
series.add(range,true); 5)加上二维图的标题
achart.Chart.HasTitle:=True;
achart.Chart.ChartTitle.Characters.Text:=' Excle二维图' 6)改变二维图的标题字体大小
achart.Chart.ChartTitle.Font.size:=6; 7)给二维图加下标说明
achart.Chart.Axes(xlCategory, xlPrimary).HasTitle := True;
achart.Chart.Axes(xlCategory, xlPrimary).AxisTitle.Characters.Text := '下标说明'; 8)给二维图加左标说明
achart.Chart.Axes(xlvalues, xlPrimary).HasTitle := True;
achart.Chart.Axes(xlvalues, xlPrimary).AxisTitle.Characters.Text := '左标说明'; 9)给二维图加右标说明
achart.Chart.Axes(xlvalues, xlSecondary).HasTitle := True;
achart.Chart.Axes(xlvalues, xlSecondary).AxisTitle.Characters.Text := '右标说明'; 10)改变二维图的显示区大小
achart.Chart.PlotArea.Left := 5;
achart.Chart.PlotArea.Width := 223;
achart.Chart.PlotArea.Height := 108; 11)给二维图坐标轴加上说明
achart.chart.seriescollection[1].NAME:='坐标轴说明'; _____________________________________________________________________
procedure TForm1.Button5Click(Sender: TObject);
var
ExcelApp,MyWorkBook,mysheet:Variant;
i :byte;
s: string;
begin
try
ExcelApp:=CreateOleObject('Excel.Application');
MyWorkBook:=CreateOleobject('Excel.Sheet');
//? MyWorkBook:=ExcelApp.workbooks.open('C:\Book1.xls');
except
on Exception do raise exception.Create('无法打开Xls文件,请确认已 经安装EXCEL')
end;
ExcelApp.Visible := true;
//? mysheet:=MyWorkBook.WorkSheets[1].name;MyworkBook:=ExcelApp.workBooks.Add;//在此处插入读数据库及写Excel文档的代码
//其中写Excel文档的关键语句如下:
Myworkbook.worksheets[1].range['A1:D1'].Merge(True);
Myworkbook.worksheets[1].range['A1:D2'].HorizontalAlignment := $FFFFEFF4;
MyWorkBook.WorkSheets[1].Cells[1,1].Value := 'YourTitle';i := 2;
MyWorkBook.WorkSheets[1].Cells[i,1].Value := 'yourCaption1';
MyWorkBook.WorkSheets[1].Cells[i,2].Value := 'yourCaption2';
MyWorkBook.WorkSheets[1].Cells[i,3].Value := 'yourCaption3';
MyWorkBook.WorkSheets[1].Cells[i,4].Value := 'yourCaption4';
Myworkbook.worksheets[1].Range['A1:D2'].Font.Color := clBlue;
Myworkbook.worksheets[1].Range['A1:D1'].Font.Name := '隶书';
Myworkbook.worksheets[1].Range['A1:D1'].Font.Size := 18;
i := 3;
table1.close;
table1.open;
table1.First;
while not table1.eof do begin
MyWorkBook.WorkSheets[1].Cells[i,1].Value := table1.FieldByName('au_id').AsString;
MyWorkBook.WorkSheets[1].Cells[i,2].Value := table1.FieldByName('royaltyper').AsInteger;
MyWorkBook.WorkSheets[1].Cells[i,3].Value := table1.FieldByName('au_ord').AsInteger;
MyWorkBook.WorkSheets[1].Cells[i,4].Value := table1.FieldByName('title_id').AsString;
Inc(i);
table1.Next
end;
ExcelApp.Visible := true;s := 'A3:D'+ IntToStr(i-1);//设定字体. 栏宽等
s := 'A1:D'+ IntToStr(i-1);
Myworkbook.worksheets[1].Columns[1].ColumnWidth := 20;
Myworkbook.worksheets[1].Columns[4].ColumnWidth := 25;
Myworkbook.worksheets[1].Rows[1].RowHeight := 50;
Myworkbook.worksheets[1].Rows[1].VerticalAlignment := $FFFFEFF4;Myworkbook.worksheets[1].Range[s].Font.Name := '仿宋';
s := 'A2:D'+ IntToStr(i-1);
Myworkbook.worksheets[1].Range[s].Borders.LineStyle := 1;
//页面设置
MyworkBook.WorkSheets[1].PageSetup.CenterHorizontally := true;
Myworkbook.worksheets[1].pagesetup.PrintTitleRows := 'A1';
//不能设置 papersize 属性, 原因不明
//MyworkBook.WorkSheets[1].PageSetup.PaperSize := $9;try
MyWorkBook.saveas('c:\' + Edit1.Text + '.xls');
MyWorkBook.close;
except //当存为一个已有的文档而又不覆盖时将
MyWorkBook.close; //产生一个例外
end;
ExcelApp.Quit;
ExcelApp:=Unassigned; //释放VARIANT变量//设置字体
eclApp.ActiveSheet.Rows[NowRow].Font.Name := TitleEdt.Font.Name;
eclApp.ActiveSheet.Rows[NowRow].Font.Color := TitleEdt.Font.Color;
eclApp.ActiveSheet.Rows[NowRow].Font.Size:=TitleEdt.Font.Size;
if fsBold in TitleEdt.Font.Style then eclApp.ActiveSheet.Rows[NowRow].Font.Bold:=true
else eclApp.ActiveSheet.Rows[NowRow].Font.Bold:=false;
if fsUnderLine in TitleEdt.Font.Style then eclApp.ActiveSheet.Rows[NowRow].Font.UnderLine := True
else eclApp.ActiveSheet.Rows[NowRow].Font.UnderLine := false;
if fsItalic in TitleEdt.Font.Style then eclApp.ActiveSheet.Rows[NowRow].Font.Italic:=true
else eclApp.ActiveSheet.Rows[NowRow].Font.Italic:=false; eclApp.ActiveSheet.Rows[NowRow].HorizontalAlignment:=xlCenter;
//合并单元格
WorkBook.worksheets[1].range['A'+inttostr(NowRow)+':'+Chr(64+ClassSetupADOQry.FieldByName('列数').AsInteger*2)+inttostr(NowRow)].Merge(True);
eclApp.ActiveSheet.Rows[NowRow].RowHeight:=strtoint(TitleRowHeightEdt.Text);