




已阅读5页,还剩6页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
下面一段代码是将EXCEL表格导入DBF数据库的实例uses comobj;procedure Texcelfrm.Button1Click(Sender: TObject);varoe:variant;n1:string;i,j:integer;beginoe:=CreateOleObject(Excel.Application);oe.visible:=true;oe.workbooks.open(FileListBox1.FileName);j:=2;/假定标题在第一行try with adoQuery1 dobeginn1:=insert into tablename(fieldslist) values(:fieldslist);close;sql.Clear;sql.Add(n);while oe.worksheetssheetname.cellsj,1.text dobeginfor i:=1 to 列数 doParameters.Itemsi-1.Value:=oe.worksheetssheetname.cellsj,i.text;execsql;j:=j+1;end;oe.visible:=false;showmessage(导入完毕);end;exceptoe.visible:=false;showmessage(数据库错误或有重复编号,请检查);end;end;回复人:gg1335回复时间:2004-8-20 9:05:00下面的代码是导出为EXCELunit Unit1;interfaceusesWindows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,Grids, DBGrids, Db, DBTables, StdCtrls, Excel97, OleServer, ComObj, ActiveX;typeTForm1 = class(TForm)Button1: TButton;Table1: TTable;DataSource1: TDataSource;DBGrid1: TDBGrid;ExcelApplication1: TExcelApplication;ExcelWorkbook1: TExcelWorkbook;ExcelWorksheet1: TExcelWorksheet;SaveDialog1: TSaveDialog;procedure Button1Click(Sender: TObject);procedure FormCreate(Sender: TObject);procedure FormDestroy(Sender: TObject);private Private declarations public Public declarations ExcelFormatNum: TStrings; /ExcelFormatNumExcelFormatStr: TStrings; /ExcelFormatStrfunction ExportDBGrid(DBGrid: TDBGrid; SheetName: string): boolean;/直接保存,不显示EXCELfunction ExportDataToExcelV(SheetName: string; DBGrid: TDBGrid; ExcelApplication: TExcelApplication;ExcelWorkbook: TExcelWorkbook; ExcelWorksheet: TExcelWorksheet): boolean; /显示EXCELfunction ConvertIntToCharacters(IntNumber: Integer): string;function GetNumberFormat(s: string): string; /判断字段的格式function FindExcelFormatStr(s: string): Boolean; /找字符格式function FindExcelFormatNum(s: string): Boolean; /找数字格式end;varForm1: TForm1;implementation$R *.DFMfunction TForm1.ExportDataToExcelV(SheetName: string; DBGrid: TDBGrid; ExcelApplication: TExcelApplication;ExcelWorkbook: TExcelWorkbook; ExcelWorksheet: TExcelWorksheet): boolean; /显示EXCEL/引用:ActiveXvarRow, Col: integer;RowFirst, ColEnd: string;lcid: integer;vNumberFormat: string;beginresult := false;if DBGrid.DataSource = nil thenexit;if DBGrid.DataSource.DataSet = nil thenexit;if DBGrid.DataSource.DataSet.IsEmpty thenexit;tryExcelApplication.Disconnect;exceptend;trytrylcid := 1; /GetUserDefaultLCID;ExcelApplication.ScreenUpdatinglcid := false;ExcelApplication.ConnectKind := ckNewInstance;ExcelApplication.Connect;exceptApplication.MessageBox(系统检测到此机器没有安装EXCEL!如果需要导出功能,请先安装EXCEL!,警告,MB_OK);exit;end;screen.Cursor := crHourGlass;ExcelWorkbook.ConnectTo(ExcelApplication.Workbooks.Add(TOleEnum(xlWBATWorksheet), lcid);ExcelWorksheet.ConnectTo(ExcelWorkbook.Worksheets1 as _Worksheet);if SheetName thenExcelWorksheet.Name := SheetName;ExcelWorksheet.Cells.Font.Size := 10;DBGrid.DataSource.DataSet.DisableControls;/导入报头for Col := 1 to DBGrid.Columns.Count doExcelWorksheet.Cells.Item1, Col.value := DBGrid.ColumnsCol - 1.Title.caption;/导入库数据DBGrid.DataSource.DataSet.First;for Col := 1 to DBGrid.Columns.Count dobeginRowFirst := ConvertIntToCharacters(Col) + 1;ColEnd := ConvertIntToCharacters(Col) + inttostr(DBGrid.DataSource.DataSet.RecordCount + 1);if DBGrid.FieldsCol - 1.DataSize 200 thenExcelWorksheet.RangeRowFirst, ColEnd.ColumnWidth := DBGrid.FieldsCol - 1.DataSizeelseExcelWorksheet.RangeRowFirst + 1, ColEnd.ColumnWidth := 21;vNumberFormat := GetNumberFormat(DBGrid.ColumnsCol - 1.Title.Caption);if vNumberFormat thenExcelWorksheet.RangeRowFirst, ColEnd.NumberFormat := vNumberFormat;for Row := 1 to DBGrid.DataSource.DataSet.RecordCount dobeginExcelWorksheet.Cells.ItemRow + 1, Col.value := trim(DBGrid.FieldsCol - 1.AsString);DBGrid.DataSource.DataSet.Next;end;DBGrid.DataSource.DataSet.First;end;ExcelApplication.Visiblelcid := True;ExcelApplication.ScreenUpdatinglcid := true;DBGrid.DataSource.DataSet.EnableControls;result := true;finallyscreen.Cursor := crDefault;end;end;function TForm1.ConvertIntToCharacters(IntNumber: Integer): string;beginif IntNumber 702 thenResult := ZZelsebeginif IntNumber 26 thenbeginif (IntNumber mod 26) = 0 thenResult := Chr(64 + (IntNumber div 26) - 1)elseResult := Chr(64 + (IntNumber div 26);if (IntNumber mod 26) = 0 thenresult := result + chr(64 + 26)elseresult := Result + Chr(64 + (IntNumber mod 26);endelseResult := Chr(64 + IntNumber);end;end;end;function TForm1.GetNumberFormat(s: string): string; /判断字段的格式begins := Uppercase(s);if FindExcelFormatNum(s) thenbeginresult := 0.00;Exit;end;if FindExcelFormatStr(s) thenbeginresult := ;Exit;end;result := ;end;function TForm1.FindExcelFormatStr(s: string): Boolean; /找字符格式vari: integer;beginResult := False;for i := 0 to ExcelFormatStr.Count - 1 dobeginif Pos(ExcelFormatStri, s) 0 thenbeginResult := True;Exit;end;end;end;function TForm1.FindExcelFormatNum(s: string): Boolean; /找数字格式vari: integer;beginResult := False;for i := 0 to ExcelFormatNum.Count - 1 dobeginif Pos(ExcelFormatNumi, s) 0 thenbeginResult := True;Exit;end;end;end;function TForm1.ExportDBGrid(DBGrid: TDBGrid; SheetName: string): boolean;/直接保存,不显示EXCEL/引用:ComObjvarc, r, i, j: integer;app: Olevariant;TempFileName, ResultFileName: string;begintryresult := True;app := CreateOLEObject(Excel.application);app.WorkBooks.Add(xlWBatWorkSheet);exceptApplication.MessageBox(Excel没有正确安装!,警告,MB_OK);result := False;exit;end;SaveDialog1.DefaultExt := xls;SaveDialog1.FileName := SheetName;if SaveDialog1.Execute thenTempFileName := SaveDialog1.FileNameelseExit;app.Workbooks.add;app.Visible := false;Screen.Cursor := crHourGlass;DBGrid.DataSource.DataSet.First;c := DBGrid.DataSource.DataSet.FieldCount;r := DBGrid.DataSource.DataSet.RecordCount;Application.ProcessMessages;for i := 0 to c - 1 doapp.cells(1, 1 + i) := DBGrid.DataSource.DataSet.Fieldsi.DisplayLabel;for j := 1 to r dobeginfor i := 0 to c - 1 doapp.cells(j + 1, 1 + i) := DBGrid.DataSource.DataSet.Fieldsi.AsString;DBGrid.DataSource.DataSet.Next;end;ResultFileName := TempFileName;if ResultFileName = thenResultFileN
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025贵州遵义医科大学附属口腔医院第十三届贵州人才博览会引进急需紧缺专业人才6人模拟试卷及1套完整答案详解
- 安全培训背景纯色课件
- 2025北京外国语大学附属外国语学校招聘模拟试卷完整答案详解
- 2025内蒙合成化工研究所工艺技能岗位招聘5人考前自测高频考点模拟试题附答案详解(模拟题)
- 2025年菏泽牡丹区区直事业单位公开引进高层次急需紧缺人才(25人)模拟试卷及参考答案详解
- 2025年河北北方学院附属第二医院选聘工作人员6名模拟试卷(含答案详解)
- 2025北京海淀十一中关村科学城学校教师招聘考前自测高频考点模拟试题含答案详解
- 2025黑龙江鸡西市博物馆现公益性岗位招聘2人模拟试卷附答案详解(突破训练)
- 2025北京市海淀区上地社区卫生服务中心招聘模拟试卷及答案详解1套
- 2025年甘肃省天水市第四人民医院招聘编外人员考前自测高频考点模拟试题附答案详解(黄金题型)
- 人力资源中薪酬管理案例分析题及答案
- 驾驶安全培训文案课件
- 采购业务审计培训
- 2025-2026学年冀美版(2024)小学美术二年级上册(全册)教学设计(附目录P284)
- 招聘渠道分析评估表
- 2025年注册安全工程师考试 安全生产法律法规与标准冲刺押题卷
- 服装色彩构成课件
- 2025年华为软件开发工程师招聘面试题库及答案解析
- 程序化广告课件
- 电工基础课件
- 真菌生物膜毒力因子-洞察及研究
评论
0/150
提交评论