DELPHI 读取EXCEL 以及将EXCEL写入到ACCESS 数据库

最近准备为公司的项目写一个小工具,要用到EXCEL文件来存放数据,并且要储存到数据,心想用惯了SQL SERVER数据库,何不直接用ACCESS数据,反正同出一家,故上网找到相关的资料,发现ADO的ADOCONNECTION 和ADOQUERY可以都读取EXCEL文件的数据和连接ACCESS数据库。于是乎,折腾了两天终于折腾了出来

1 。首先是读取EXCEL文件中的数据并显示到DBGrid中,这里用到了ADOQuery 控件,DataSource控件,以及DBGRID控件,话不多说,直接上代码:

var
  FilePath:string;
  str1,SqlStr:string;

// 这里是选取要读取的EXCEL文件
begin
  if dlgOpen_FileSelect.Execute then
  begin
    if dlgOpen_FileSelect.FileName<>'' then
    begin
      FilePath:=dlgOpen_FileSelect.FileName;
      Edit1.Text:=FilePath;
    end
    else
      ShowMessage('请选择正确的文件');
  end;

// 这里连接EXCEL文件
  try

    str1:='Provider=Microsoft.Jet.OLEDB.4.0;Data Source='+FilePath+';Extended Properties=Excel 8.0;Persist Security Info=False';
    ADOQuery1.Close;
    ADOQuery1.ConnectionString:=str1;

//    ShowMessage(str1);

    SqlStr:='select * from [Sheet1$]' ;
//    ShowMessage(SqlStr);


    ADOQuery1.SQL.Clear;
    ADOQuery1.SQL.Add(SqlStr);
    ADOQuery1.Open;

    ds1.DataSet:=ADOQuery1;
    RzDBGrid1.DataSource:= ds1;
  finally

  end;

第一部分选择EXCEL文件就不讲了,连接EXCEL文件直接采用多ADOQUERY控件连接字符串赋值的方法,str1:='Provider=Microsoft.Jet.OLEDB.4.0;Data Source='+FilePath+';Extended Properties=Excel 8.0;Persist Security Info=False';

其中Microsoft.Jet.OLEDB.4.0表示读取的EXCEL表格式为【97--2003】的EXCEL文件,即后缀为.xls的文件,至于.xlsx的文件会报错,网上找了下好好像必须将Microsoft.Jet.OLEDB.4.0改为Microsoft.Jet.OLEDB.8.0.然后EXCEL8.0 改为EXCEL 12.0?然而我ADO空间里的连接属性并没有Microsoft.Jet.OLEDB.8.0选项,如果有大佬测试成功请评论告知我

剩下简单的控件设置,直接将DBGRID连到ADOQUERY1就行,测试结果如下(由于篇幅关系只截取前两列):

 

2 将EXCEL数据写如ACCESS 数据库

好了接下来是重头戏,如何将EXCEL表中写入ACCESS数据库中呢?,首先我们先看下代码:

var
  FilePath:string;
  ConStr:string;
  SQLstr:string;
  s1:TStringList;
  tableName:string;
  I:Integer;
begin
  if Application.MessageBox('是否真要的导入数据?导入将会覆盖之前的数据','提示',MB_YESNO)= mrYes then
  begin
    if Edit1.Text='' then
    begin
      ShowMessage('请选择要输入的数据文件');
    end
    else
    begin
       try
// 方法 1: 
          //连接要写入的EXECL文件
          FilePath:=Edit1.Text;
          ADOConnection1.Connected:=False;
          ConStr:='Provider=Microsoft.Jet.OLEDB.4.0;Data Source='+FilePath+';Extended Properties=Excel 8.0;Persist Security Info=False';
          ADOConnection1.ConnectionString:=ConStr;
          ADOConnection1.Connected:=True;

          s1:=TStringList.Create;
          ADOConnection1.GetTableNames(s1);// 获取表的名称,S1是一个列表,保存所有的表名
          tableName:=s1[0];

          // 这里应该是将EXCEL表的所有的数据保存到ADOquery

          ADOEXCEL.Close;
          ADOEXCEL.SQL.Clear;
          tableName := '[' + tableName + ']' ;
          ADOEXCEL.SQL.Text:='Select * From '+tableName;
//          ShowMessage(ADOEXCEL.SQL.Text);
          ADOEXCEL.Open;
          s1.Free;

          // 先清空数据表
           ADOConnection2.Connected:=True;
           ADOQuery2.SQL.Clear;
           // 这里用TEXT 会报凑,提示没有结果集返回,因为表被清空了,用ADD +EXCCSQL
           ADOQuery2.SQL.Add('delete * from [TEST] where ID>0' );
           ADOQuery2.ExecSQL;
           ADOQuery2.Close;



          // 打开要连接的数据库中的表
          ADOQuery2.SQL.Clear;
          ADOQuery2.SQL.Text:='select * from  TEST';
          ADOQuery2.Open;

//          ShowMessage(ADOEXCEL.RecordCount.ToString);

          // 将EXCEL数据导入ACCESS数据库中的表
           if ADOEXCEL.RecordCount>0 then
           begin
               ADOEXCEL.First;
               for I := 1 to ADOEXCEL.RecordCount do
               BEGIN
                    ADOQuery2.Append;
                    ADOQuery2.FieldValues['ID']:=ADOEXCEL.FieldValues['ID'];
                    ADOQuery2.FieldValues['PNum']:=ADOEXCEL.FieldValues['PNum'];
                    ADOQuery2.FieldValues['PName']:=ADOEXCEL.FieldValues['PName'];
                    ADOQuery2.FieldValues['PDepartment']:=ADOEXCEL.FieldValues['PDepartment'];
                    ADOQuery2.FieldValues['Date_In']:=ADOEXCEL.FieldValues['Date_In'];
                    ADOQuery2.FieldValues['Date_Year']:=ADOEXCEL.FieldValues['Date_Year'];
                    ADOQuery2.FieldValues['VocationDays']:=ADOEXCEL.FieldValues['VocationDays'];
                    ADOQuery2.FieldValues['AreadyDays']:=ADOEXCEL.FieldValues['AreadyDays'];
                    ADOQuery2.FieldValues['LastDays']:=ADOEXCEL.FieldValues['LastDays'];
                    ADOQuery2.FieldValues['DepartmentNum']:=ADOEXCEL.FieldValues['DepartmentNum'];
                    ADOQuery2.Post;

                    ADOEXCEL.Next;
               END;
//
//
           end;



// 方法2:
//           将数据写进数据库 :不能扩充选定范围
//           FilePath:=Trim(Edit1.Text) ;
//           ADOQuery1.Close;
//           ADOQuery1.SQL.Clear;
//           SQLstr:='INSERT INTO Test (ID,PNum,PName,PDepartment,Date_In,Date_Year,VocationDays,AreadyDays,LastDays,DepartmentNum)'
//           +'select' +
//           ' ID,PNum,PName,PDepartment,Date_In,Date_Year,VocationDays,AreadyDays,LastDays,DepartmentNum'+
//           ' FROM [excel 8.0;database=' + FilePath + '].[Sheet1$]';
//           ShowMessage(SQLstr);
//
//           ADOQuery1.ParamCheck:=False;
//           ADOQuery1.SQL.Text:=SQLstr;
//           ADOQuery1.ExecSQL;

       finally
            ShowMessage('数据导入成功');
       end;
    end;
  end;

通过资料查找发现有两者方法来实现数据的导入,我们先来看看第一种,这里用的还是ADO控件,简单的说就是准备两个ADOCONNECTION 控件和两个ADOQUERY控件,其中,Adoconnection1和Adoquery1用来连接数据库中的表,(没有表的请手动建立或者自行添加创建表语句)Adoconnection2和Adoquery2 用来连接要储存的EXCEL表,然后就是简单的SELECT语句把数据库表中的数据作为结果集存在Adoquery1中,把excel表的数据存放再Adoquery2 中,然后循环读取:ADOQuery1.FieldValues['字段名']:=Adoquery2 .FieldValues['字段名'],然后就OK了,这里要注意ACCESS没有清空表的语句,但可以用DELETE * FROM XX WHERE 条件的方法来清除,是不是很简单,最终取得的结果如下:

第二种方法是直接使用语句:

SQLstr:='INSERT INTO Test (ID,PNum,PName,PDepartment,Date_In,Date_Year,VocationDays,AreadyDays,LastDays,DepartmentNum)'
           +'select' +
         ' ID,PNum,PName,PDepartment,Date_In,Date_Year,VocationDays,AreadyDays,LastDays,DepartmentNum'+  ' FROM [excel 8.0;database=' + FilePath + '].[Sheet1$]';

如代码所示,这里要注意语句的空格,但是这种方式报错,显示不能【不能超出显示范围】,这个我也是一直没测试通过,等可以后我再更新把

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
//▎============================================================▎// //▎================① 扩展的字符串操作函数 ===================▎// //▎============================================================▎// //从文件中返回Ado连接字串。 function GetConnectionString(DataBaseName:string):string; //返回服务器的机器名称. function GetRemoteServerName:string; function InStr(const sShort: string; const sLong: string): Boolean; {测试通过} {* 判断s1是否包含在s2中} function IntToStrEx(Value: Integer; Len: Integer; FillChar: Char = '0'): string; {测试通过} {* 扩展整数转字符串函数 Example: IntToStrEx(1,5,'0'); 返回:"00001"} function IntToStrSp(Value: Integer; SpLen: Integer = 3; Sp: Char = ','): string; {测试通过} {* 带分隔符的整数-字符转换} function ByteToBin(Value: Byte): string; {测试通过} {* 字节转二进制串} function StrRight(Str: string; Len: Integer): string; {测试通过} {* 返回字符串右边的字符 Examples: StrRight('ABCEDFG',3); 返回:'DFG' } function StrLeft(Str: string; Len: Integer): string; {测试通过} {* 返回字符串左边的字符} function Spc(Len: Integer): string; {测试通过} {* 返回空格串} function Replace(Str,s1,s2:string;CaseSensitive:Boolean):string; {测试通过} {* 返回将指定字符s1用字符串s2替换后的字符串,可支持大小写敏感由CaseSensitive操作} {example: replace('We know what we want','we','I',false) = 'I Know what I want'} function Replicate(pcChar:Char; piCount:integer):string; {在一个字符串中查找某个字符串的位置} function StrNum(ShortStr:string;LongString:string):Integer; {测试通过} {* 返回某个字符串中某个字符串中出现的次数} function FindStr(ShortStr:String;LongStrIng:String):Integer; {测试通过} {* 返回某个字符串中查找某个字符串的位置} function SubStr(psInput:String; BeginPlace,CutLeng:Integer):String; {测试通过} {* 返回从位置BeginPlace开始切取长度为CatLeng字符串} function LeftStr(psInput:String; CutLeng:Integer):String; {测试通过} {* 返回从左边第一为开始切取 CutLeng长度的字符串} function RightStr(psInput:String; CutLeng:Integer):String; {测试通过} {* 返回从右边第一为开始切取 CutLeng长度的字符串} function PadLStr(psInput:String; piWidth:Integer; pcPadWith:Char):String; {测试通过} {* 返回从psInput字符串左边开始用pcPadWith填充后总长度为PiWidth的字符串} function PadRStr(psInput:String; piWidth:Integer; pcPadWith:Char):String; {测试通过} {* 返回从psInput字符串右边开始用pcPadWith填充后总长度为PiWidth的字符串} function PadCStr(psInput:String; piWidth:Integer; pcPadWith:Char):String; {测试通过} {* 返回从psInput字符串两边开始用pcPadWith填充后总长度为PiWidth的字符串} function ChrTran(psInput:String; pcSearch:Char; pcTranWith:Char):String; {测试通过} {* 返回替换后字符串[替换单个字符] Examples: ChrTran('abCdEgdlkh','d','#'); 返回'abC#Eg#lkh'} function StrTran(psInput:String; psSearch:String; psTranWith:String):String; {测试通过} {* 返回替换后字符串[替换字符串] Examples: StrTran('aruyfbn','ruy','=====');; 返回'a=====fbn'} function Stuff(psInput:String; piBeginPlace,piCount:Integer; psStuffWith:String):String; { *返回替换后字符串[替换字符串] Examples: Stuff('ABCDEFGHI',3,4,'12345');返回'AB12345GHI'} procedure SwapStr(var s1, s2: string); {测试通过} {* 交换字串} function LinesToStr(const Lines: string): string; {测试通过} {* 多行文本转单行(换行符转'\n')} function StrToLines(const Str: string): string; {测试通过} {* 单行文本转多行('\n'转换行符)} function Encrypt(const S: String; Key: Word): String; {* 字符串加密函数} function Decrypt(const S: String; Key: Word): String; {* 字符串解密函数} function varIIF(aTest: Boolean; TrueValue, FalseValue: Variant): Variant; function varToStr(const V: Variant): string; {* VarIIF及VartoStr为变体函数} function IsDigital(Value: string): boolean; {功能说明:判断string是否全是数字} function RandomStr(aLength : Longint) : String; {随机字符串函数} //▎============================================================▎// //▎================② 扩展的日期时间操作函数 =================▎// //▎============================================================▎// function GetYear(Date: TDate): Integer; {测试通过} {* 取日期年份分量} function GetMonth(Date: TDate): Integer; {测试通过} {* 取日期月份分量} function GetDay(Date: TDate): Integer; {测试通过} {* 取日期天数分量} function GetHour(Time: TTime): Integer; {测试通过} {* 取时间小时分量} function GetMinute(Time: TTime): Integer; {测试通过} {* 取时间分钟分量} function GetSecond(Time: TTime): Integer; {测试通过} {* 取时间秒分量} function GetMSecond(Time: TTime): Integer; {测试通过} {* 取时间毫秒分量} function GetMonthLastDay(Cs_Year,Cs_Month:string):string; { *传入年、月,得到该月份最后一天} function IsLeapYear( nYear: Integer ): Boolean; {*/判断某年是否为闰年} function MaxDateTime(const Values: array of TDateTime): TDateTime; {//两个日期取较大的日期} function MinDateTime(const Values: array of TDateTime): TDateTime; {//两个日期取较小的日期} function dateBeginOfMonth(D: TDateTime): TDateTime; {//得到本月的第一天} function DateEndOfMonth(D: TDateTime): TDateTime; {//得到本月的最后一天} function DateEndOfYear(D: TDateTime): TDateTime; {//得到本年的最后一天} function DaysBetween(Date1, Date2: TDateTime): integer; {//得到两个日期相隔的天数} //▎============================================================▎// //▎===================③ 扩展的位操作函数 ====================▎// //▎============================================================▎// type TByteBit = 0..7; {* Byte类型位数范围} TWordBit = 0..15; {* Word类型位数范围} TDWordBit = 0..31; {* DWord类型位数范围} procedure SetBit(var Value: Byte; Bit: TByteBit; IsSet: Boolean); overload; {* 设置二进制位} procedure SetBit(var Value: WORD; Bit: TWordBit; IsSet: Boolean); overload; {* 设置二进制位} procedure SetBit(var Value: DWORD; Bit: TDWordBit; IsSet: Boolean); overload; {* 设置二进制位} function GetBit(Value: Byte; Bit: TByteBit): Boolean; overload; {* 取二进制位} function GetBit(Value: WORD; Bit: TWordBit): Boolean; overload; {* 取二进制位} function GetBit(Value: DWORD; Bit: TDWordBit): Boolean; overload; {* 取二进制位} //▎============================================================▎// //▎=================④扩展的文件及目录操作函数=================▎// //▎============================================================▎// function MoveFile(const sName, dName: string): Boolean; {测试通过} {* 移动文件、目录,参数为源、目标名} procedure FileProperties(const FName: string); {测试通过} {* 打开文件属性窗口} function CreatePath(path : string) : Boolean; function OpenDialog(var FileName: string; Title: string; Filter: string; Ext: string): Boolean; {* 打开文件框} function FormatPath(APath: string; Width: Integer): string; {测试通过} {* 缩短显示不下的长路径名} function GetRelativePath(Source, Dest: string): string; {测试通过} {* 取两个目录的相对路径,注意串尾不能是'\'字符!} procedure RunFile(const FName: string; Handle: THandle = 0; const Param: string = ''); {测试通过} {* 运行一个文件} function WinExecAndWait32(FileName: string; Visibility: Integer = SW_NORMAL): Integer; {测试通过} {* 运行一个文件并等待其结束} function AppPath: string; {测试通过} {* 应用程序路径} function GetDiskInfo(sFile : string; var nDiskFree,nDiskSize : Int64): boolean; {测试通过} {* 取sFile 所在磁盘空间状态 } function GetWindowsDir: string; {测试通过} {* 取Windows系统目录} function GetWinTempDir: string; {测试通过} {* 取临时文件目录} function AddDirSuffix(Dir: string): string; {测试通过} {* 目录尾加'\'修正} function MakePath(Dir: string): string; {测试通过} {* 目录尾加'\'修正} function IsFileInUse(FName: string): Boolean; {测试通过} {* 判断文件是否正在使用} function GetFileSize(FileName: string): Integer; {测试通过} {* 取文件长度} function SetFileDate(FileName: string; CreationTime, LastWriteTime, LastAccessTime: TFileTime): Boolean; {测试通过} {* 设置文件时间 Example: FileSetDate('c:\Test\Test1.exe',753160662); } function GetFileDate(FileName: string; var CreationTime, LastWriteTime, LastAccessTime: TFileTime): Boolean; {测试通过} {* 取文件时间} function FileTimeToLocalSystemTime(FTime: TFileTime): TSystemTime; {测试通过} {* 文件时间转本地时间} function LocalSystemTimeToFileTime(STime: TSystemTime): TFileTime; {测试通过} {* 本地时间转文件时间} function GetFileIcon(FileName: string; var Icon: TIcon): Boolean; {测试通过} {* 取得与文件相关的图标,成功则返回True} function CreateBakFile(FileName, Ext: string): Boolean; {测试通过} {* 创建备份文件} function Deltree(Dir: string): Boolean; {测试通过} {* 删除整个目录} function GetDirFiles(Dir: string): Integer; {测试通过} {* 取文件夹文件数} type TFindCallBack = procedure(const FileName: string; const Info: TSearchRec; var Abort: Boolean); {* 查找指定目录下文件的回调函数} procedure FindFile(const Path: string; const FileName: string = '*.*'; Proc: TFindCallBack = nil; bSub: Boolean = True; const bMsg: Boolean = True); {* 查找指定目录下文件} procedure FindFileList(Path:string;Filter,FileList:TStrings;ContainSubDir:Boolean; lb: TLabel=nil); { 功能说明:查找一个路径下的所有文件。 参数: path:路径,filter:文件扩展名过滤,FileList:文件列表, ContainSubDir:是否包含子目录} function Txtline(const txt: string): integer; {* 返回一文本文件的行数} function Html2Txt(htmlfilename: string): string; {* Html文件转化成文本文件} function OpenWith(const FileName: string): Integer; {测试通过} {* 文件打开方式} //▎============================================================▎// //▎====================⑤扩展的对话框函数======================▎// //▎============================================================▎// procedure InfoDlg(Mess: string; Caption: string = SCnInformation; Flags: Integer = MB_OK + MB_ICONINFORMATION); {测试通过} {* 显示提示窗口} function InfoOk(Mess: string; Caption: string = SCnInformation): Boolean; {测试通过} {* 显示提示确认窗口} procedure ErrorDlg(Mess: string; Caption: string = SCnError); {测试通过} {* 显示错误窗口} procedure WarningDlg(Mess: string; Caption: string = SCnWarning); {测试通过} {* 显示警告窗口} function QueryDlg(Mess: string; Caption: string = SCnInformation): Boolean; {测试通过} {* 显示查询是否窗口} procedure SetWindowAnimate(Sender : TForm; IsSetAni : bool); //▎============================================================▎// //▎=====================⑥系统功能函数=========================▎// //▎============================================================▎// procedure MoveMouseIntoControl(AWinControl: TControl); {测试通过} {* 移动鼠标到控件} function DynamicResolution(x, y: WORD): Boolean; {测试通过} {* 动态设置分辨率} procedure StayOnTop(Handle: HWND; OnTop: Boolean); {测试通过} {* 窗口最上方显示} procedure SetHidden(Hide: Boolean); {测试通过} {* 设置程序是否出现在任务栏} procedure SetTaskBarVisible(Visible: Boolean); {测试通过} {* 设置任务栏是否可见} procedure SetDesktopVisible(Visible: Boolean); {测试通过} {* 设置桌面是否可见} procedure BeginWait; {测试通过} {* 显示等待光标} procedure EndWait; {测试通过} {* 结束等待光标} function CheckWindows9598NT: string; {测试通过} {* 检测是否Win95/98/NT平台} function GetOSInfo : String; {测试通过} {* 取得当前操作平台是 Windows 95/98 还是NT} function GetCurrentUserName : string; {*获取当前Windows登录名的用户} function GetRegistryOrg_User(UserKeyType:string):string; {*获取当前注册的单位及用户名称} function GetSysVersion:string; {*//获取操作系统版本号} function WinBootMode:string; {//Windows启动模式} type PShutType = (UPowerOff, UShutdown, UReboot, ULogOff, USuspend, UHibernate); procedure WinShutDown(ShutWinType:PShutType; PForce:Boolean); {//Windows ShutDown等} //▎============================================================▎// //▎=====================⑦硬件功能函数=========================▎// //▎============================================================▎// function GetClientGUID:string; { 功能描述:在本机上得到一个GUID.去掉两端的大括号和中间的横线 返回值:去掉两端的大括号和中间的横线的一个GUID 适用范围:windows } function SoundCardExist: Boolean; {测试通过} {* 声卡是否存在} function GetDiskSerial(DiskChar: Char): string; {* 获取磁盘序列号} function DiskReady(Root: string) : Boolean; {*检查磁盘准备是否就绪} procedure WritePortB( wPort : Word; bValue : Byte ); {* 写串口} function ReadPortB( wPort : Word ) : Byte; {*读串口} function CPUSpeed: Double; {* 获知当前机器CPU的速率(MHz)} type TCPUID = array[1..4] of Longint; function GetCPUID : TCPUID; assembler; register; {*获取CPU的标识ID号*} function GetMemoryTotalPhys : Dword; {*获取计算机的物理内存} type TDriveState = (DSNODISK, DSUNFORMATTEDDISK, DSEMPTYDISK, DSDISK_WITHFILES); function DriveState (driveletter: Char) : TDriveState; {* 检查驱动器A中磁盘是否有效} //▎============================================================▎// //▎=====================⑧网络功能函数=========================▎// //▎============================================================▎// function GetComputerName:string; {* 获取网络计算机名称} function GetHostIP:string; {* 获取计算机的IP地址} function NetUserChangePassword(Domain:PWideChar; UserName:PWideChar; OldPassword:PWideChar; NewPassword:PWideChar): LongInt; stdcall; external 'netapi32.dll' name 'NetUserChangePassword'; {* // 运行平台:Windows NT/2000/XP {* // Windows 95/98/Me平台:可以用该函数修改用户的Windows登录密码} //▎============================================================▎// //▎=====================⑨汉字拼音功能函数=====================▎// //▎============================================================▎// function GetHzPy(const AHzStr: string): string; {测试通过} {* 取汉字的拼音} function HowManyChineseChar(Const s:String):Integer; {* 判断一个字符串中有多少各汉字} //▎============================================================▎// //▎===================⑩数据库功能函数及过程===================▎// //▎============================================================▎// {function PackDbDbf(Var StatusMsg: String): Boolean;} {* 物理删除数据库(Db,Dbf)中的数据[着了删除标记的记录]} procedure RepairDb(DbName: string); {* 修复Access表} function CreateODBCCfgInRegistry(ODBCSourceName:WideString;ServerName, DataBaseDescription:String):boolean; {* 通过注册表创建ODBC配置[创建在系统DSN页下]} function ADOConnectSysBase(Const Adocon:TadoConnection):boolean; {* 用Ado连接SysBase数据库函数} function ADOConnectLocalDB(Const Adocon:TadoConnection;Const Dbname,DbServerName:string;ValidateMode:Integer):boolean; {* 用Ado连接数据库函数} function ADOODBCConnectLocalDB(Const Adocon:TadoConnection;Const Dbname:string;ValidateMode:Integer):boolean; {* 用Ado与ODBC共同连接数据库函数} function CreatTable(LpDataBaseName,LpTableName,LpSentence:string):Boolean; {* //建立新表} function AddField(LpFieldName:string; LpDataType: TFieldType; LpSize: Word):string; {*//在表中添加字段} function KillField(LpFieldName:string):String; {* //在表中删除字段} function AlterTableExec(LpDataBaseName,LpSentence:string):Boolean; {* //修改表结构} function GetSQLSentence(LpTableName,LpSQLsentence:string): string; {* /修改、添加、删除表结构时的SQL句体} //▎============================================================▎// //▎======================⑾进制函数及过程======================▎// //▎============================================================▎// function StrToHex(AStr: string): string; {* 字符转化成十六进制} function HexToStr(AStr: string): string; {* 十六进制转化成字符} function TransChar(AChar: Char): Integer; //▎============================================================▎// //▎=====================⑿其它函数及过程=======================▎// //▎============================================================▎// function TrimInt(Value, Min, Max: Integer): Integer; overload; {测试通过} {* 输出限制在Min..Max之间} function IntToByte(Value: Integer): Byte; overload; {测试通过} {* 输出限制在0..255之间} function InBound(Value: Integer; Min, Max: Integer): Boolean; {测试通过} {* 判断整数Value是否在Min和Max之间} procedure CnSwap(var A, B: Byte); overload; {* 交换两个数} procedure CnSwap(var A, B: Integer); overload; {* 交换两个数} procedure CnSwap(var A, B: Single); overload; {* 交换两个数} procedure CnSwap(var A, B: Double); overload; {* 交换两个数} function RectEqu(Rect1, Rect2: TRect): Boolean; {* 比较两个Rect是否相等} procedure DeRect(Rect: TRect; var x, y, Width, Height: Integer); {* 分解一个TRect为左上角坐标x, y和宽度Width、高度Height} function EnSize(cx, cy: Integer): TSize; {* 返回一个TSize类型} function RectWidth(Rect: TRect): Integer; {* 计算TRect的宽度} function RectHeight(Rect: TRect): Integer; {* 计算TRect的高度} procedure Delay(const uDelay: DWORD); {测试通过} {* 延时} procedure BeepEx(const Freq: WORD = 1200; const Delay: WORD = 1); {Win9X下测试通过} {* 只能在Win9X下让喇叭发声} procedure ShowLastError; {测试通过} {* 显示Win32 Api运行结果信息} function writeFontStyle(FS: TFontStyles; inifile: string; write: boolean):string; {* 将字体Font.Style写入INI文件} function readFontStyle(inifile: string): TFontStyles; {* 从INI文件中读取字体Font.Style文件} //function ReadCursorPos(SourceMemo: TMemo): TPoint; function ReadCursorPos(SourceMemo: TMemo): string; {* 取得TMemo 控件当前光标的行和列信息到Tpoint中} function CanUndo(AMemo: TMemo): Boolean; {* 检查Tmemo控件能否Undo} procedure Undo(Amemo: Tmemo); {*实现Undo功能} procedure AutoListDisplay(ACombox:TComboBox); {* 实现ComBoBox自动下拉} function UpperMoney(small:real):string; {* 小写金额转换为大写 } function Myrandom(Num: Integer): integer; {*利用系统时间产生随机数)} procedure OpenIME(ImeName: string); {*打开输入法} procedure CloseIME; {*关闭输入法} procedure ToChinese(hWindows: THandle; bChinese: boolean); {*打开中文输入法} //数据备份 procedure BackUpData(LpBackDispMessTitle:String); procedure ImageLoadGif(Picture: TPicture; filename: string); procedure ImageLoadJpg(Picture: TPicture; filename: string);
Win32.pas API函数的简单调用,如建立进程,建立文件映射,建立、读取管道(可以捕捉DOS程序输出)等。 StrFuncs.pas 字符串处理单元,完全兼容宽字节处理(即使用wideString),特有的中文字符串处理函数(如简繁转换等等),经过多次优化,大多以编表的方式进行处理(一般来说是最快的处理方式)。 BiosHelp.pas  读取Bios信息的单元,兼容各种windows系统。 Streams.pas  流(TStream)输入输出处理单元,可以用来保存读取控件属性。 ShlFile.pas  各种文件操作,包括获得系统特殊路径,获取文件图标等。 RegExpr.pas  一个规则表达式类的单元。 ShareMemRep.pas  一个可以用来替代Delphi本身的内存管理的单元。 MessageDlg.pas 提供了一个高制定性的消息对话框。 Lists.pas  提供了很多个TList的扩展类,是学习很研究TList的好东西。 Calendar.pas  公历与农历换算和时间处理的函数单元,具体看里面的说明。 Clipboards.pas 提供一个剪贴板增强类,可支持保存和载入剪贴板,支持多重剪贴板。 ComputerInfo.pas 完整的系统信息检测单元,从软件到硬件,从CPU到鼠标,很全面。 AccessCtrls.pas 一个Access数据库操作单元。 FastIniFile.pas  可以用来替换DELPHI提供的慢吞吞的IniFiles单元,并且支持更多写入读出类型。 EnumStuff.pas 一个募举进程和窗口列表的单元,兼容各种Windows系统。 DES.pas  DES加密算法单元。 AES.pas  AES加密算法单元。 CryptoAPI.pas  一个完整的Hash算法单元,如MD5、CRC之类等等。 FastMM.pas  国外很著名的内存管理单元,Delphi2006的内存管理单元用的就是它。 FastStrings.pas  一个快速字符串处理单元,一些函数用汇编写的,处理速度比DELPHI本身的字符串处理快很多,不过不支持WideString类型。 Idpacker.pas  压缩文件类型检测单元。 ZLibEx.pas  纯Pascal代码的快速压缩解压单元,压缩率和速度都不错。 FastStringFuncs.pas  基于FastStrings.pas单元的应用。
### 回答1: Delphi是一种编程语言,可以使用它来读取写入Excel文件。这需要使用Delphi的相关库和组件来实现。 要读取Excel文件,我们可以使用Delphi的OLE对象,通过创建和操作Excel应用程序对象来实现。首先需要引入Excel的类型库,然后创建Excel应用程序对象,打开需要读取Excel文件,选择工作表和单元格,读取和处理数据。可以使用各种Delphi的技术和功能来处理Excel数据,如字符串处理、循环、条件语句等。 要写入Excel文件,也可以使用Delphi的OLE对象来实现。首先需要创建Excel应用程序对象,然后打开或创建一个Excel文件,选择工作表和单元格,设置需要写入的数据。通过使用Delphi的相应方法和属性,可以将数据写入指定的单元格中。写入完成后,可以保存并关闭Excel文件。 在读取写入Excel文件时,还需要处理异常情况,如文件不存在、格式错误等。可以使用Delphi的异常处理机制来捕获和处理这些异常,以保证程序的稳定性和可靠性。 总之,使用Delphi编程语言可以方便地读取写入Excel文件。通过合理应用Delphi的相关库和组件,结合数据处理和异常处理的技巧,可以实现灵活、高效的Excel文件操作功能。 ### 回答2: delphi是一种用于开发Windows应用程序的编程语言,而Excel是一种常用的电子表格软件。在delphi中,我们可以使用某些库或组件来实现对Excel文件的读取写入操作。 要读取Excel文件,可以使用delphi中的数据连接组件,如ADO(ActiveX Data Objects)或dbExpress。通过这些组件,我们可以连接到Excel文件,选择所需的数据表或工作表,然后使用SQL查询语句来检索数据。我们还可以使用一些功能强大的类库,如TExcelFile和TXLSReadWrite来读取和解析Excel文件。 在写入Excel文件方面,我们可以使用delphi提供的COM接口来操作Excel应用程序。可以通过创建Excel应用程序对象,在其内部创建工作簿对象,并在工作簿中创建工作表。然后,我们可以使用各种方法和属性来设置单元格的值、格式和公式。最后,可以保存并关闭Excel文件。 需要注意的是,为了在delphi中使用Excel操作,需要安装Microsoft Excel程序,并将其注册到操作系统或项目中。 总结来说,通过使用delphi提供的库、组件和接口,我们可以很容易地实现对Excel文件的读取写入操作。无论是数据报表、数据导入导出还是数据分析,delphi都提供了丰富的工具和方法来满足我们的需求。 ### 回答3: Delphi可以通过操作Excel读取写入数据。首先,我们需要使用DelphiExcel组件来实现这两个功能。 对于读取Excel数据,我们可以使用OleVariant类型的变量来存储Excel应用程序和工作簿对象。我们可以使用下面的代码来实现: ``` var ExcelApp: Variant; ExcelWorkbook: Variant; ExcelSheet: Variant; RowCount, ColumnCount, i, j: Integer; begin ExcelApp := CreateOleObject('Excel.Application'); ExcelWorkbook := ExcelApp.Workbooks.Open('路径\文件名.xlsx'); ExcelSheet := ExcelWorkbook.Worksheets[1]; RowCount := ExcelSheet.UsedRange.Rows.Count; ColumnCount := ExcelSheet.UsedRange.Columns.Count; for i := 1 to RowCount do begin for j := 1 to ColumnCount do begin ShowMessage(ExcelSheet.Cells[i, j].Value); end; end; ExcelWorkbook.Close; ExcelApp.Quit; end; ``` 上述代码首先创建了Excel应用程序对象和工作簿对象。然后,我们可以通过指定工作表的索引来获取工作表对象。通过UsedRange属性,我们可以确定Excel表格中使用的行数和列数。使用Cells属性,我们可以获取单元格的值。 对于写入Excel数据,我们可以使用下面的代码: ``` var ExcelApp: Variant; ExcelWorkbook: Variant; ExcelSheet: Variant; i, j: Integer; begin ExcelApp := CreateOleObject('Excel.Application'); ExcelApp.Visible := True; ExcelWorkbook := ExcelApp.Workbooks.Add; ExcelSheet := ExcelWorkbook.Worksheets[1]; for i := 1 to 10 do begin for j := 1 to 5 do begin ExcelSheet.Cells[i, j].Value := '数据' + IntToStr(i) + '-' + IntToStr(j); end; end; ExcelWorkbook.SaveAs('路径\文件名.xlsx'); ExcelWorkbook.Close; ExcelApp.Quit; end; ``` 上述代码首先创建了Excel应用程序对象和新的工作簿对象。通过Visible属性,我们可以使Excel应用程序可见。然后,使用Cells属性将数据写入工作表中。最后,通过SaveAs方法将工作簿保存为指定的文件,并关闭应用程序。 总结起来,通过使用DelphiExcel组件,我们可以方便地实现Excel数据的读取写入功能。以上仅为示例代码,实际操作需要根据具体的需求和Excel文件的结构进行适当地修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值