TXLSReadWriteII导出Excle (有点复杂,可以自己简化一下,直接从项目中抓取的)

procedure TformSubReport.DataToExcel(_Item: Integer; _Obj: TObject);                         //导出Excle

var

  i, j, k: Integer;

  aVendorObj: TVendor;

  aEnterpriseObj: TEnterprise;

  aXlsObj: TXLSReadWriteII;

  aFileName: AnsiString;

  aCarRec: PCarRec;

  aOnLine: AnsiString;

  aRecordCount: Integer;                                                       //Excel数据条数

  aEnterpriseCount: Integer;                                                   //统计企业有多少行 + 合计一行

  aBookmark: Integer;                                                          //记录运营商的起始位置

  aMergedCell: TMergedCell;

  aFontIndex: Integer;

  aStampTime: AnsiString;

  aVendorName: AnsiString;

begin

  if _Item = 1 then

    _Obj := nil;

  aRecordCount := 0;

  aEnterpriseCount := 0;

  SaveDialog1.InitialDir := ExtractFilePath(ParamStr(0));

  SaveDialog1.DefaultExt := 'xls';

  SaveDialog1.Filter := 'Excel文件(*.xls)|*.xls|所有文件(*.*)|*.*';

  aStampTime := FormatDateTime('yyyymmddhhnnss', Now);

  SaveDialog1.FileName := aStampTime;

  if not SaveDialog1.Execute then

    Exit;

  aFileName := SaveDialog1.FileName;

  if aFileName = '' then

    Exit;

  aXlsObj := TXLSReadWriteII.Create(nil);

  try

    aXlsObj.Sheets[0].NameWideString('统计报表' + aStampTime);                 //工作表命名

    with aXlsObj.Formats.Add do                                                //定义格式一

    begin

      aFontIndex := aXlsObj.Fonts.AddIndex;

      aXlsObj.Fonts[aFontIndex].Name := '黑体';

      aXlsObj.Fonts[aFontIndex].Size := 14;

      aXlsObj.Fonts[aFontIndex].Color := xcRed;                                //字体颜色无效。shit

      HorizAlignment := chaCenter;

      VertAlignment := cvaCenter;

      FillPatternForeColor := xcLilac;

    end;

    with aXlsObj.Formats.Add do                                                //定义格式二

    begin

      HorizAlignment := chaCenter;

      VertAlignment := cvaCenter;

    end;

    case _item of

      1:begin

          aXlsObj.Sheets[0].WriteWideString(0, 0, 1, '运营商名称');

          aXlsObj.Sheets[0].WriteWideString(1, 0, 1, '企业名称');

          aXlsObj.Sheets[0].WriteWideString(2, 0, 1, '轨迹数总数');

          aXlsObj.Sheets[0].WriteWideString(3, 0, 1, '超速报警总数');

          aXlsObj.Sheets[0].WriteWideString(4, 0, 1, '车辆总数');

          aXlsObj.Sheets[0].WriteWideString(5, 0, 1, '在线车辆总数');

          aXlsObj.Sheets[0].WriteWideString(6, 0, 1, '在线率(%)');

        end;

    else

      begin

        aXlsObj.Sheets[0].WriteWideString(0, 0, 1, '序号');

        aXlsObj.Sheets[0].WriteWideString(1, 0, 1, '运营商名称');

        aXlsObj.Sheets[0].WriteWideString(2, 0, 1, '企业名称');

        aXlsObj.Sheets[0].WriteWideString(3, 0, 1, '定位时间');

        aXlsObj.Sheets[0].WriteWideString(4, 0, 1, '车牌号码');

        aXlsObj.Sheets[0].WriteWideString(5, 0, 1, '轨迹数');

        aXlsObj.Sheets[0].WriteWideString(6, 0, 1, '超速报警数');

        aXlsObj.Sheets[0].WriteWideString(7, 0, 1, '疲劳驾驶报警数');

        aXlsObj.Sheets[0].WriteWideString(8, 0, 1, '是否在线');

      end;

    end;

    if _Obj = nil then

    begin

      for i := 0 to FVendorHash.Count - 1 do

      begin

        aVendorObj := FVendorHash[i];

        if aVendorObj = nil then Continue;

        aBookmark := aEnterpriseCount;

        aEnterpriseCount := 0;

        for j := 0 to aVendorObj.EnterpriseHash.Count - 1 do

        begin

          aEnterpriseObj := aVendorObj.EnterpriseHash[j];

          if aEnterpriseObj = nil then Continue;

          if _Item = 1 then

          begin

            inc(aRecordCount);

            inc(aEnterpriseCount);

            aXlsObj.Sheets[0].WriteWideString(0, aRecordCount, 2, aVendorObj.DataRec.VendorName);

            aXlsObj.Sheets[0].AsWideString[1, aRecordCount] := aEnterpriseObj.DataRec.EnterpriseName;

            aXlsObj.Sheets[0].AsFloat[2, aRecordCount] := aEnterpriseObj.TotalInfo.TotalGpsCount;

            aXlsObj.Sheets[0].AsFloat[3, aRecordCount] := aEnterpriseObj.TotalInfo.TotalOverAlarm;

            aXlsObj.Sheets[0].AsFloat[4, aRecordCount] := aEnterpriseObj.TotalInfo.TotalCarCount;

            aXlsObj.Sheets[0].AsFloat[5, aRecordCount] := aEnterpriseObj.TotalInfo.TotalOnLine;

            aXlsObj.Sheets[0].AsFloat[6, aRecordCount] := aEnterpriseObj.TotalInfo.OnlineRate;

          end

          else

          begin

            for k := 0 to aEnterpriseObj.CarHash.Count - 1 do

            begin

              aCarRec := aEnterpriseObj.CarHash[k];

              if _Item = 2 then //在线

              begin

                if not aCarRec.IsLine then Continue;

                aOnLine := '在线';

              end

              else if _Item = 3 then //离线

              begin

                if aCarRec.IsLine then Continue;

                aOnLine := '离线';

              end

              else if _Item = 4 then //所有

              begin

                if aCarRec.IsLine then

                  aOnLine := '在线'

                else

                  aOnLine := '离线';

              end;

              inc(aRecordCount);

              inc(aEnterpriseCount);

              aXlsObj.Sheets[0].AsInteger[0, aRecordCount] := aRecordCount;

              aXlsObj.Sheets[0].AsWideString[1, aRecordCount] := aVendorObj.DataRec.VendorName;

              aXlsObj.Sheets[0].AsWideString[2, aRecordCount] := aEnterpriseObj.DataRec.EnterpriseName;

              aXlsObj.Sheets[0].AsWideString[3, aRecordCount] := DateTimeToStr(aCarRec.ReportDate);

              aXlsObj.Sheets[0].AsWideString[4, aRecordCount] := aCarRec.RegistrationNO;

              aXlsObj.Sheets[0].AsFloat[5, aRecordCount] := aCarRec.GpsCount;

              aXlsObj.Sheets[0].AsFloat[6, aRecordCount] := aCarRec.OverSpeedAlarmCount;

              aXlsObj.Sheets[0].AsFloat[7, aRecordCount] := aCarRec.DriverFatigueAlarmCount;

              aXlsObj.Sheets[0].AsWideString[8, aRecordCount] := aOnLine;

            end;

          end;

        end;

        if _Item = 1 then                                   //小计

        begin

          Inc(aRecordCount);

          Inc(aEnterpriseCount);

          aXlsObj.Sheets[0].WriteWideString(0, aRecordCount, 2, aVendorObj.DataRec.VendorName);

          aXlsObj.Sheets[0].WriteWideString(1, aRecordCount, 2, '小计');

          aXlsObj.Sheets[0].AsFloat[2, aRecordCount] := aVendorObj.TotalInfo.TotalGpsCount;

          aXlsObj.Sheets[0].AsFloat[3, aRecordCount] := aVendorObj.TotalInfo.TotalOverAlarm;

          aXlsObj.Sheets[0].AsFloat[4, aRecordCount] := aVendorObj.TotalInfo.TotalCarCount;

          aXlsObj.Sheets[0].AsFloat[5, aRecordCount] := aVendorObj.TotalInfo.TotalOnLine;

          aXlsObj.Sheets[0].AsFloat[6, aRecordCount] := aVendorObj.TotalInfo.OnlineRate;

          aMergedCell := aXlsObj.Sheets[0].MergedCells.Add;

          aMergedCell.Col1 := 0;

          aMergedCell.Row1 := aBookmark + 1;

          aMergedCell.Col2 := 0;

          aMergedCell.Row2 := aBookmark + aEnterpriseCount;                    //这里的值是对应Excel中最后一行的地址

        end;

      end;

    end

    else if _Obj is TVendor then

    begin

      for j := 0 to TVendor(_Obj).EnterpriseHash.Count - 1 do

      begin

        aEnterpriseObj := TVendor(_Obj).EnterpriseHash[j];

        if aEnterpriseObj = nil then Continue;

        for k := 0 to aEnterpriseObj.CarHash.Count - 1 do

        begin

          aCarRec := aEnterpriseObj.CarHash[k];

          if _Item = 2 then //在线

          begin

            if not aCarRec.IsLine then Continue;

            aOnLine := '在线';

          end

          else if _Item = 3 then //离线

          begin

            if aCarRec.IsLine then Continue;

            aOnLine := '离线';

          end

          else if _Item = 4 then //所有

          begin

            if aCarRec.IsLine then

              aOnLine := '在线'

            else

              aOnLine := '离线';

          end;

          inc(aRecordCount);

          aXlsObj.Sheets[0].AsInteger[0, aRecordCount] := aRecordCount;

          aXlsObj.Sheets[0].AsWideString[1, aRecordCount] := TVendor(_Obj).DataRec.VendorName;

          aXlsObj.Sheets[0].AsWideString[2, aRecordCount] := aEnterpriseObj.DataRec.EnterpriseName;

          aXlsObj.Sheets[0].AsWideString[3, aRecordCount] := DateTimeToStr(aCarRec.ReportDate);

          aXlsObj.Sheets[0].AsWideString[4, aRecordCount] := aCarRec.RegistrationNO;

          aXlsObj.Sheets[0].AsFloat[5, aRecordCount] := aCarRec.GpsCount;

          aXlsObj.Sheets[0].AsFloat[6, aRecordCount] := aCarRec.OverSpeedAlarmCount;

          aXlsObj.Sheets[0].AsFloat[7, aRecordCount] := aCarRec.DriverFatigueAlarmCount;

          aXlsObj.Sheets[0].AsWideString[8, aRecordCount] := aOnLine;

        end;

      end;

    end

    else if _Obj is TEnterprise then

    begin

      aVendorObj := FVendorHash.ValueOf(IntToStr(TEnterprise(_Obj).DataRec.VendorID));

      if aVendorObj = nil then

        Exit;

      aVendorName := aVendorObj.DataRec.VendorName;

      for k := 0 to TEnterprise(_Obj).CarHash.Count - 1 do

      begin

        aCarRec := TEnterprise(_Obj).CarHash[k];

        if _Item = 2 then                         //在线

        begin

          if not aCarRec.IsLine then Continue;

          aOnLine := '在线';

        end

        else if _Item = 3 then                    //离线

        begin

          if aCarRec.IsLine then Continue;

          aOnLine := '离线';

        end

        else if _Item = 4 then                    //所有

        begin

          if aCarRec.IsLine then

            aOnLine := '在线'

          else

            aOnLine := '离线';

        end;

        inc(aRecordCount);

        aXlsObj.Sheets[0].AsInteger[0, aRecordCount] := aRecordCount;

        aXlsObj.Sheets[0].AsWideString[1, aRecordCount] := aVendorName;

        aXlsObj.Sheets[0].AsWideString[2, aRecordCount] := TEnterprise(_Obj).DataRec.EnterpriseName;

        aXlsObj.Sheets[0].AsWideString[3, aRecordCount] := DateTimeToStr(aCarRec.ReportDate);

        aXlsObj.Sheets[0].AsWideString[4, aRecordCount] := aCarRec.RegistrationNO;

        aXlsObj.Sheets[0].AsFloat[5, aRecordCount] := aCarRec.GpsCount;

        aXlsObj.Sheets[0].AsFloat[6, aRecordCount] := aCarRec.OverSpeedAlarmCount;

        aXlsObj.Sheets[0].AsFloat[7, aRecordCount] := aCarRec.DriverFatigueAlarmCount;

        aXlsObj.Sheets[0].AsWideString[8, aRecordCount] := aOnLine;

      end;

    end;

    if (_Item = 1) and (_Obj = nil) then                                       //汇总

    begin

      Inc(aRecordCount);

      aXlsObj.Sheets[0].WriteWideString(0, aRecordCount, 2, '汇总');

      aXlsObj.Sheets[0].AsInteger[1, aRecordCount] := FTotalEnterpriseCount;

      aXlsObj.Sheets[0].AsFloat[2, aRecordCount] := FTotalInfo.TotalGpsCount;

      aXlsObj.Sheets[0].AsFloat[3, aRecordCount] := FTotalInfo.TotalOverAlarm;

      aXlsObj.Sheets[0].AsFloat[4, aRecordCount] := FTotalInfo.TotalCarCount;

      aXlsObj.Sheets[0].AsFloat[5, aRecordCount] := FTotalInfo.TotalOnLine;

      aXlsObj.Sheets[0].AsFloat[6, aRecordCount] := FTotalInfo.OnlineRate;

    end;

    aXlsObj.Filename := aFileName;

    aXlsObj.Write;

    Information(Format('导出文件'+#13#10+'%s'+#13#10 +'成功!', [aFileName]));

  finally

    aXlsObj.Free;

  end;

end;

  

Delphi TXLSReadWriteII导出Excel的更多相关文章

  1. Delphi TXLSReadWriteII 导出EXCEL

    unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms ...

  2. Delphi DBGridEh导出Excel

    unit Unit_DBGridEhToExcel; interface uses SysUtils, Variants, Classes, Graphics, Controls, Forms, Ex ...

  3. Delphi+DBGrid导出Excel

    uses ComObj; //DBGrid:指定的DBGrid;SaveFileName:要保存的文件名 function ExportDBGrid(DBGrid: TDBGrid; SaveFile ...

  4. delphi cxgrid导出excel去除货币符号

    版本 : devexpress 13.1.4 打开 包在ExpressExportLibary目录中.  修改FCells.SetCellDataCurrency为FCells.SetCellData ...

  5. Delphi 数据导出到Excel

    好多办公软件特别是财务软件,都需要配备把数据导出到Excel,下面就来介绍两种数据导出方法 1.ADODB导出查询结果(此方法需要安装Excel) 2.二维表数据导出(根据Excel文件结构生成二进制 ...

  6. CxGrid导出Excel时清除颜色的设置

    CxGrid导出Excel时清除颜色的设置 (2011-04-25 16:33:23) 转载▼ 标签: it 分类: Delphi http://www.radxe.com/?p=170 cxgrid ...

  7. C#使用Aspose.Cells导出Excel简单实现

    首先,需要添加引用Aspose.Cells.dll,官网下载地址:http://downloads.aspose.com/cells/net 将DataTable导出Xlsx格式的文件下载(网页输出) ...

  8. 利用poi导出Excel

    import java.lang.reflect.Field;import java.lang.reflect.InvocationTargetException;import java.lang.r ...

  9. [django]数据导出excel升级强化版(很强大!)

    不多说了,原理采用xlwt导出excel文件,所谓的强化版指的是实现在网页上选择一定条件导出对应的数据 之前我的博文出过这类文章,但只是实现导出数据,这次左思右想,再加上网上的搜索,终于找出方法实现条 ...

随机推荐

  1. phpMyAdmin 尝试连接到 MySQL 服务器,但服务器拒绝连接 解决办法

    phpMyAdmin 尝试连接到 MySQL 服务器,但服务器拒绝连接.您应该检查配置文件中的主机.用户名和密码,并确认这些信息与 MySQL 服务器管理员所给出的信息一致. 原因有可能是因为修改了m ...

  2. win10 家庭版修改hosts的权限

    https://jingyan.baidu.com/article/624e7459b194f134e8ba5a8e.html

  3. Linux下FTP服务器(vsftpd)配置:

    1. vsftpd 安装:yum install vsftpd 2. 添加用于: useradd admin -d /home/data -s /sbin/nologin usermod -d /ho ...

  4. Chromium Settings页面修改

    /********************************************************************** * Chromium Settings页面修改 * 说明 ...

  5. WEBBASE篇: 第七篇, JavaScript知识1

    JavaScript 1 一.JavaScript 概述什么是JavaScript: JavaScript 简称 JS,是一种专门运行于JS解释器/引擎中的解释型脚本语言JS发展史: 1.1992年N ...

  6. 文本对齐方式(text-align)

    text-align 设置元素内文本的水平对齐方式. 属性值:left.right.center.justify 注:该属性对块级元素设置有效.

  7. SQLI DUMB SERIES-12

    (1)检测闭合方式:在username上输入" admin" " 说明输入的username后还有双引号和括号 方法一: (2)通过其他途径知道用户名即可.如 输入&qu ...

  8. 仿QQ菜单栏:消息,电话菜单

    转载自:http://blog.csdn.net/johnnyz1234/article/details/45919907 在实际项目开发使用Fragment的时候,也碰到一些异常和存在的问题,下面做 ...

  9. Socket基础之-启动异步服务侦听

    Socket网络编程第一篇: 本文主要是以代码为主. .NET技术交流群 199281001 .欢迎加入 1 //负责监听的套接字 private Socket socketServer; //通知一 ...

  10. PythonStudy——进制 System of numeration

    十进制 人类天然选择了十进制. 二进制 二进制有两个特点:它由两个数码0,1组成,二进制数运算规律是逢二进一. 四进制 四进制是以4为基数的进位制,以 0.1.2 和 3 四个数字表示任何实数. 七进 ...