zoukankan      html  css  js  c++  java
  • delphi 导出 excel

    procedure Tfrm_main.XLGW_Excel(p_int_Row_Begin, p_int_Col_Begin,
      p_int_Row_End, p_int_Col_End: Integer; p_str_Value, p_str: String);
    var
      m_Query : TADOQuery;
      m_StringList_FieldNames : TStringList;
      m_int,rowid : Integer;
      m_int_Row : Integer;
      ExcelApp,ExcelObj:TExcel;  //引用excel单元
      m_str,Astr : String;
      HJXLCD:string;
      i:Integer;  //用于控制列宽变量
    begin
      m_Query := TADOQuery.Create(nil);
        ExcelObj:=TExcel.Create;
        try
          {填写表头}
          m_Query.Connection:= sqlclass.conn;
          m_str := p_str;
          m_Query.Close;
          m_Query.SQL.Clear;
          m_Query.SQL.Add(m_str);
          try
            m_Query.Open;
          except
            ShowMessage('报表输出失败,请重新计算!');
            Exit;
          end;
          if m_Query.IsEmpty then
          begin
            ShowMessage('没有要导出的数据!');
            Exit;
          end;
          if not ExcelObj.New_WorkBook then    //显示工作薄
          begin
            ShowMessage('新建工作簿失败');
            Exit;
          end;
          try
          //页面设置                       //纵向xlPortrait       //横向xlLandscape
          ExcelObj.SetSheetPage(xlPaperA4,xlLandscape,0.6,0.6,0.6,0.6,0.3,0.3);
          except
          end;
          ExcelObj.IsVisible(True);  //控制是否显示Excel
          m_StringList_FieldNames := TStringList.Create;
          m_Query.GetFieldNames(m_StringList_FieldNames);
          ExcelObj .SetCell('序号',2,1,0);
          for m_int := 1 to m_StringList_FieldNames.Count do
          begin
            //设置指定单元格的值
            ExcelObj.SetCell(m_StringList_FieldNames.Strings[m_int - 1],2, m_int+1,0);
          end;

        {写入数据}
          rowid :=0;
          m_int_Row := 3;  //行
          while not  m_Query.Eof do
          begin
            rowid:=rowid+1;
            ExcelObj.SetCell(IntToStr(rowid),m_int_Row, 1,1); //加序号
            for m_int := 1 to m_StringList_FieldNames.Count do
            begin
              //判断输出字段类型
              //  (0:字符型;1:整形;2,3:数值型)  增加清零操作
              Astr:= m_Query.FieldByName(m_StringList_FieldNames.Strings[m_int - 1]).AsString;
             { if m_Query.Fields[m_int - 1].DataType in [ftSmallint, ftInteger,ftBCD ] then
              begin
                if (Astr = '') or (StrtoInt(Astr)=0) then
                begin
                  Continue;
                end;
               //ExcelObj.SetCell(Astr,m_int_Row, m_int+1,1);    //weixing 20100707
              end
              else }
                if  m_Query.Fields[m_int - 1].DataType in [ftWord,ftFloat] then
                begin
                    if (Astr = '') or (StrtoFloat(Astr)=0) then
                    begin
                      Continue;
                    end;
                   ExcelObj.SetCell(Astr,m_int_Row, m_int+1,2);
                end
                else if m_Query.Fields[m_int - 1].DataType in [ftInteger] then  //weixing 20100707
                begin
                    if (Astr = '') or (StrtoFloat(Astr)=0) then
                    begin
                      Continue;
                    end;
                    ExcelObj.SetCell(Astr,m_int_Row, m_int+1,1);
                end
                else
                begin
                  ExcelObj.SetCell(Astr,m_int_Row, m_int+1,0);
                end;//if
             end; //if
           // end;//for
            m_int_Row := m_int_Row + 1;
            m_Query.Next;
          end;//While
            for i:=1 to 13 do
            begin
              if (i=1) then
                ExcelObj.SetColumnWidth(i,24)
               else
                ExcelObj.SetColumnWidth(i,7);
             end;
          for m_int:=1 to m_int_Row-1 do
          begin
            ExcelObj.SetRowHeight(m_int,18); //设置指定行的行高
            //单元格居中
            ExcelObj.SetRowHorizontalAlignment(m_int,xlHAlignCenter);
            ExcelObj.SetRowVerticalAlignment(m_int,xlHAlignCenter);
          end;
          p_int_Col_End:=m_StringList_FieldNames.Count;
          {设置表格函数}
          ExcelObj.MergeCells(p_int_Row_Begin, p_int_Col_Begin,p_int_Row_End, p_int_Col_End);//合并单元格
          //设置标题指定范围的值
          ExcelObj.SetRangeValue(1,1,p_int_Row_Begin, p_int_Col_Begin,p_str_Value);
          //生成标题参数设置
          ExcelObj.SetRowFontStyle(p_int_Row_Begin,'加粗','宋体',0,15);
          //标题行高
          ExcelObj.SetRowHeight(1,33); //设置指定行的行高

          //加单元格
          ExcelObj.SetRangeOutBorderStyle(2,1,m_int_Row-1, m_StringList_FieldNames.Count+1,2,0,1);//单元格外部加边线
          ExcelObj.SetRangeInnerLineStyle(2,1,m_int_Row-1, m_StringList_FieldNames.Count+1,2,0,1);//单元格内部加边线
          ExcelObj.SetRangeAutoWrap(3,1,3, m_StringList_FieldNames.Count);//指定行自动换行
          //ExcelObj.SetRowFontStyle(3,'加粗','宋体',0,12);//生成排头参数设置
          //最后一行合计所有数值字段
          //ExcelObj.SetRangeValue(m_int_Row,1,m_int_Row,1,'合计'); //往单元格写入'合计';
         { for m_int := 1 to m_StringList_FieldNames.Count do
            //行列号为: m_int_Row,m_int ;
          begin
            if m_Query.Fields[m_int - 1].DataType in [ftSmallint, ftInteger, ftWord,ftFloat,ftBCD] then
            begin
              HJXLCD:=FloatToStr(ExcelObj.Sum(4,m_int,m_int_Row,m_int)); //合计线路长度
              ExcelObj.SetRangeValue(m_int_Row,m_int,m_int_Row,m_int,HJXLCD);
            end;
          end; }
          ExcelObj.CellAutoFit;//自动列宽
          m_StringList_FieldNames.free;
       finally
          m_Query.Free;
          ExcelObj.Destroy;
       end;
    end;
    {利用OLE技术实现的与Excel应用程序的接口
     可以实现表格设计,数据输出,模板定制,
     打印设置,打印预览,打印表格等功能;}

    unit Excel_Unit;{单元名称}

    interface{接口部分}
    uses
      Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms, Dialogs,
      Excel97,OleServer, StdCtrls,Variants,ExcelConst_Unit,ComObj;
    const

      //报表平面图参数
      pm_Title = '配 电 线 路 条 图';

      pm_PageRows = 21;

      pm_PageOffset = 530;//     //页与页之间图形距离

      pm_LineLeft   = 123;       //线起始left
      pm_LineTop    = 72;//74;   //线起始top
      pm_LineRight  = 727;//705; //线终止right //水平所以没有y坐标

      pm_GanFirstLeft = 118;     //最左第一个杆的left坐标
      pm_GanOffset    = 60;      //杆间距
      pm_GanTop  = 166;//67;     //杆距顶top
      pm_GanD    = 10;           //杆径  12
      pm_BYQD    = 13;//14;      //变压器大小  13
      pm_BYQY    = -7;           //变压器距杆距离  20

      pm_Distance = 27;//30;     //转角箭头线段长

      dm_GanTop = 143.25;        //断面杆
      dm_HaiBa = 0;              //海拔
      dm_HuChui = 5;             //导线下垂弧度

    //下面记录类型用于绘制平断面图  
    type
      TRecData = record
        XLMC: String;   //线路名称
        GH: String;     //杆号
        GX: String;     //电杆种类及杆型
        GG: String;     //杆高
        MS: String;     //埋深
        DXPL: String;   //导线排列
        DXXH: String;   //导线型号
        DJ: String;     //档距
        LJCD: String;   //累计长度
        ZJBZ: Integer;  //画转角标志   1: 画转角 0: 不画转角
        ZJ: String;     //线路转角
        JCKY: String;   //交叉跨越
        CZJL: String;   //垂直距离
        HDGG: String;   //横担规格
        LXWZ: String;   //拉线位置
        LXXHGS: String; //拉线型号/根数
        JYZXHSL: String;//绝缘子型号/数量
        GZZSY: String;  //故障指示仪
        BTXS: String;   //变台型式
        PBRL: String;   //配变容量
        HM: String;     //户名
        BLQGG: String;  //避雷器规格
        BLQSL: String;  //避雷器数量
        KGGG: String;   //开关规格
        KGSL: String;   //开关数量
        FZ1ZJ: String;  //分支1转角
        FZ2ZJ: String;  //分支2转角
        FZ1MC: String;  //分支1名称
        FZ2MC: String;  //分支2名称
        IsCable: Integer; //是否有电缆 1: 电缆 0: 不是电缆
        IsTJPole: Integer;  //是否是引出分支杆
      end;
      PRecData = ^TRecData;

    type
      TWindowObject = record
                        WinHandle  : HWnd;    {Window Handle}
                        WinCaption : String;  {Window Caption Text (If any)}
                        ProcessID  : Integer; {Process the window belongs to}
                        IsVisible  : Boolean; {Is the window visible?}
                        IsEnabled  : Boolean; {Is the window enabled for mouse/keyboard input?}
                        IsIconic   : Boolean; {Is the window minimized?}
                        WindowRect : TRect;   {Window Dimensions}
                        {Add more properties here if you like,
                         then fill them in at the WindowCallback
                         function.}
                      end;
      PTWindowObject = ^TWindowObject;

    //Excel操作类
      TExcel = class(TObject)
      private
        MyExcel: Variant;             //存储Excel对象
        Book :Variant;               //当前工作表
        Sheet:Variant;               //当前工作表
      protected
        { protected declarations }
        function GetRowNum(TStr:string):Integer;   //获取指定单元格的行号()
        function GetColNum(TStr:string):Integer; //获取指定单元格的行号
      public
        { Public declarations }
        IsPageSetup:Boolean;         //是否进行了页面设置
        Template_Path:string;        //模板路径
        Template_Name:string;        //模板名称
        Template_OpenName:String;    //打开的模板的名称
        ActiveSheet:Integer;      //当前活动的页
        UsedRowBeg:Integer;       //当前已使用的起始行
        UsedColBeg:Integer;       //当前已使用的起始列
        UsedRowEnd:Integer;       //当前已使用的终止行
        UsedColEnd:Integer;       //当前已使用的终止列
        CurRowBeg:Integer;        //要使用的起始行
        CurColBeg:Integer;        //要使用的起始列
        CurRowEnd:Integer;        //要使用的终止行
        CurColEnd:Integer;        //要使用的终止列
        //下面为类操作
        Constructor Create();                                        //创建Excel对象
        Destructor Destroy; virtual;                                 //释放Excel对象
        //Excel操作
        procedure IsVisible(IsOrNo:Boolean);                         //控制Excel是否显示
        procedure IsAlert(IsOrNo:Boolean);                           //控制Excel是否出现警告存盘的对话框
        function  SetActiveWindowGridVisible(IsVisible:Boolean=True):Boolean;        //设置当前窗口网格的显示与否
        function  SaveToFile(AFileName:string):Boolean;              //Excel数据保存到文件
        procedure ExitExcel;                                         //退出Excel

        //工作簿操作
        function  New_WorkBook:Boolean;                                 //新建工作簿
        function  OpenExcelFile(FileName:string): Boolean;              //打开指定的Excel文件
        function  IsWorkbookExit:Integer;                               //判断是否存在工作簿
        //工作表操作
        function SetCurrentSheet(SheetNum:Integer):Boolean;             //设置当前工作表
        function GetSheetsNameList(var FileName:TstringList):Boolean;   //得到工作簿中工作表名称列表
        function GetSheetRange:string;                                  //获取当前工作表中的工作范围
        function SetSheetPage(APageType,Orientation:Integer;LeftMargin,RightMargin,TopMargin,
                 BottomMargin,HeaderMargin,FooterMargin:Double):Boolean;   //对指定的工作表进行页面设置
        //Range或Cell操作
        function  GetCell(Row,Col:Integer):Variant;                        //得到当前工作表中某行某列的值
        procedure SetCell(Value: String; Row, Col: Integer;AType:Integer); //设置指定单元格的值
        function  GetRangeValue(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer):String;                    //获取指定范围的值
        function  SetRangeValue(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer;AValue:string):Boolean;     //设置指定范围的值
        function  InsertPicIntoSheet(ABeginRow,ABeginCol:Integer;APicFile:String):Boolean;//向指定工作表中插入图片
        function  Sum(BeginRow,BeginCol,EndRow,EndCol:Integer):Double;                    //对指定单元格间的值求和
        //文本框操作
        function  InsertTextBox(AX,AY,AWidth,AHeight:Double;AOrient:Integer=msoTextOrientationHorizontalRotatedFarEast):Variant;//在指定位置插入文本框
        function  SetTextBoxFillStyle(ATextBox:Variant;AVisible:Integer;ATransparency:Double=0):Boolean;  //设置文本框填充样式
        function  SetTextBoxLineStyle(ATextBox:Variant;AVisible:Integer;ATransparency:Double=0):Boolean;  //设置文本框边框样式
        function  SetTextBoxFontStyle(ATextBox:Variant;AFontName,AFontStyle:String;
                  AFontSize:Integer = 12;AFontColor:Integer=0):Boolean;                     //设置文本框中字体样式
        function  SetTextBoxAlignment(ATextBox:Variant;HAlign:Integer=xlLeft;VAlign:Integer=xlBottom):Boolean; //设置文本框水平和垂直对齐方式
        function  SetTextBoxText(ATextBox:Variant;AText:string):Boolean;                    //设置文本框中文字内容
        //格式化单元格操作
        function  MergeCells(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer):Variant;  //合并单元格
        procedure CellAutoFit;                                                              //设置单元格为自动列宽
        //格式化行高和列宽
        function  SetColumnWidth(AColNum:Integer;AColWidth:Double):Boolean;                 //设置指定列的宽度
        function  SetRowHeight(ARowNum:Integer;ARowHeight:Double):Boolean;                  //设置指定行的行高
        function  SetRangeColWidth(ABeginRow,ABeginCol,AEndRow,AEndCol:Integer;AColWidth:Double):Boolean; //设置指定范围内单元格的列宽
        //格式化指定区域范围
        function  SetRangeFontStyle(BeginRow,BeginCol,EndRow, EndCol:Integer;
                                    AFontStyle:string='常规';AFontName:string='宋体';
                                    AFontColor:Integer=0;AFontSize:Integer=12):Boolean;               //设置范围
        function  SetRowFontStyle(ARowNum:Integer;AFontStyle:string='常规';AFontName:string='宋体';
                                    AFontColor:Integer=0;AFontSize:Integer=12):Boolean;               //设置指定行的字体样式
        function  SetColumnFontStyle(AColNum:Integer;AFontStyle:string='常规';AFontName:string='宋体';
                                     AFontColor:Integer=0;AFontSize:Integer=12):Boolean;              //设置指定列的字体样式

        function  SetRangeOutBorderStyle(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer;
                                     AWeight:Integer=2;ALineColor:Integer=0;ALineStyle:Integer=xlContinuous):Boolean; //设置指定范围的外边框样式

        function SetRowOutBorderStyle(ARowNum:Integer;AWeight:Integer=2;
                                     ALineColor:Integer=0;ALineStyle:Integer=xlContinuous):Boolean;        //设置指定行的外边框样式
        function SetColumnOutBorderStyle(AColNum:Integer;AWeight:Integer=2;ALineColor:Integer=0;           //设置指定列的外边框样式
                                    ALineStyle:Integer=xlContinuous):Boolean;

        function  SetRangeInnerLineStyle(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer;
                       AWeight:Integer=2;ALineColor:Integer=0;ALineStyle:Integer=xlContinuous):Boolean;   //设置指定范围的分隔线样式

        function  SetRowInnerLineStyle(ARowNum:Integer;AWeight:Integer=2;ALineColor:Integer=0;
                                    ALineStyle:Integer=xlContinuous):Boolean;                            //设置指定行的分隔线样式
        function  SetColumnInnerLineStyle(AColNum:Integer;AWeight:Integer=2;ALineColor:Integer=0;
                                    ALineStyle:Integer=xlContinuous):Boolean;                            //设置指定列的分隔线样式

        function  SetRangeHorizontalAlignment(ABegRowNum,ABegColNum,AEndRowNum,
                                   AEndColNum:Integer;AAlign:Integer=xlLeft):Boolean;               //设置范围的水平对其方式
        function  SetRangeVerticalAlignment(ABegRowNum,ABegColNum,AEndRowNum,
                                   AEndColNum:Integer;AAlign:Integer=xlBottom):Boolean;             //设置范围的垂直对其方式
        function  SetRowHorizontalAlignment(ARowNum:Integer;AAlign:Integer=xlLeft):Boolean;         //设置指定行的水平对其方式
        function  SetRowVerticalAlignment(ARowNum:Integer;AAlign:Integer=xlBottom):Boolean;         //设置指定行的垂直平对其方式
        function  SetColumnHorizontalAlignment(AColNum:Integer;AAlign:Integer=xlLeft):Boolean;      //设置指定列的水平对其方式
        function  SetColumnVerticalAlignment(AColNum:Integer;AAlign:Integer=xlBottom):Boolean;      //设置指定列的垂直对其方式

        function  SetRangeAutoWrap(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer):Boolean;    //设置指定区域格式为自动换行
        function  CancelRangeAutoWrap(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer):Boolean; //取消指定区域的自动换行
        function  SetRangeBackGround(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer;
                   APattern:Integer=xlSolid;APatternColor:Integer=xlNone;ABackColor:Integer=xlNone):Boolean;   //设置指定范围的背景图案

        //格式化箭头线
        function FormatArrowLineEndHead(ALine:Variant;AheadStyle:Integer=msoArrowheadTriangle;
                 AheadLength:Integer=msoArrowheadLengthMedium;AheadWidth:Integer=msoArrowheadWidthMedium):Boolean;  //格式化箭头线的末端样式
        function FormatArrowLineBeginHead(ALine:Variant;AheadStyle:Integer=msoArrowheadTriangle;
                 AheadLength:Integer=msoArrowheadLengthMedium;AheadWidth:Integer=msoArrowheadWidthMedium):Boolean; //格式化箭头线的首端样式
        function  FormatArrowLine(ALine:Variant;AWidth:Double=1.5;AStyle:Integer=msoLineSingle;ADashStyle:Integer=msoLineSolid):Boolean;  //格式化箭头线的线样式
        //数据库中数据转为Excel操作
        procedure SetTheFieldsName(AFields:TStringList;BeginRow,BeginCol,FieldNumber:Integer;IsNeedXuHao:Boolean); //设置Excel工作表中的列名
        procedure TransferDataToExcel(FieldValues:Array of TStringList;BeginRow,BeginCol,FieldNumber,RcdNumber:Integer;IsNeedXuHao:Boolean); //转换数据到Excel
        procedure DataToExcelUpPage(FieldValues:Array of TStringList;BeginRow,BeginCol,FieldNumber,
                  RcdNumber:Integer;IsNeedXuHao:Boolean;IsHengXiangOrZongXiang:Boolean=False); //使用Excel将指定的数据打印输出
        //
        procedure Print_PageSetup();                            //打印页面设置
        procedure Print_PrintView;                              //打印预览
        procedure Print_PrintOut;                               //打印输出
        //
        function  Get_Template_Path():String;                  //获取模板路径
        procedure Set_Template_Path(PathName:String);          //设置模板路径
        procedure Set_Template_OpenName(TemplateName:String);  //设置打开模板的名称
        function  Open_Template():Variant;  //打开模板
        procedure Save_Template();  //保存模板
        //
        procedure SetTableTitle(TitleName:String;BeginRow,BeginCol,Row,Col,FontSize:integer;
                                IsNeedXuHao:Boolean=False;IsNeedFrame:Boolean=True);  //设置表的标题(表头)
        //绘制平断面图
        procedure CreatePage(APage: Integer;ABDZMC, AXLMC: String;AValueList: TStringList); //创建页
        procedure FormatCells(APage, AColNum, ARow: Integer;AColName: String
                                              ;AValueList: TStringList);             //绘制平断面图时根据不同情况格式化单元格
        procedure GetCellDMGanCoord(APage, ACellIndex: Integer;var AX, AY: Double);  //获取指定页,指定cell的断面杆的中心坐标
        procedure CreateDMT(AX1, AY1, AGanGao: Double;AIsTJPole, AIsFirstPole,
                     AIsCable: Boolean;var AOldY2: Double);                         //创建断面图
        procedure GetCellGanCoord(APage, ACellIndex: Integer;var AX, AY: Double);   //获取指定页,指定cell的杆的中心坐标
        procedure CreateFZLine(AX, AY,AYOffSet,AAngle: Double;AXLMC: String);       //画分支  创建转角箭头线
        procedure CreateArrowheadLine(AX, AY, AAngle: Double);                      //创建转角箭头线
        function  DoubleToFenMiao(Jiao:Double):string;                              //双精度的度转换为度分秒
        procedure DrawBYQText(AX, AY : Double;AText: String);                       //绘制变压器文本
        procedure DrawBYQ(AX, AY : Double);                                         //绘制变压器
        function GetPoleHight(AHight: Double): Double;                              //以15米杆高为标准计算d当前杆塔图形高度
        //暂不使用的功能
        function  FindTheExcelMainWindow:Integer;          //辅助工程找出当前系统环境中的运行的excel的主窗体句柄:
        procedure DisableSystemCloseBox;                   //使当前Excel应用程序的关闭按钮失效

        //
      Published
        { Published declarations }
      end;

    const
      RcdCountOfEachPageOfHengXiang=22;
      RcdCountOfEachPageOfZongXiang=44;

    var
      MyWindowPtr : ^TWindowObject;
      V_PageOffset: Double;

    implementation {实现部分}



    { Excel }


    {
    功能描述:创建Excel对象
    输入参数: 无
    输出参数:无
    创建时间: 2006-04-07
    创建人:  赵占轻
    }
    constructor TExcel.Create();
    begin
      Inherited;
      try
        MyExcel:=CreateOleObject('Excel.Application');             //创建Excel对象
      except
      end;
      //
    //  New(MyWindowPtr);
      //
    end;

    {
    功能描述:使用Excel将指定的数据打印输出
    输入参数:FieldValues              待输出的数据列表
              BeginRow                 起始行号
              BeginCol                 起始列号
              FieldNumber              字段数
              RcdNumber                记录数
              IsNeedXuHao              是否需要序号
              IsHengXiangOrZongXiang   纵向还是横向 (True:纵向False:横向)
    输出参数:无
    创建时间:2006-04-13
    创建人:  赵占轻
    }
    procedure TExcel.DataToExcelUpPage(FieldValues: array of TStringList; BeginRow,
      BeginCol, FieldNumber, RcdNumber: Integer; IsNeedXuHao: Boolean;IsHengXiangOrZongXiang:Boolean=False);
    var
      nPageNumber,nLastPageRcdCount,i,nTmp:Integer;
      vSheet:Variant;
    begin
      if IsHengXiangOrZongXiang then
      begin
        nLastPageRcdCount:=(RcdNumber mod RcdCountOfEachPageOfZongXiang);
        nPageNumber:=((RcdNumber-nLastPageRcdCount) div RcdCountOfEachPageOfZongXiang);
        ntmp:=RcdCountOfEachPageOfZongXiang;
      end else
      begin
        nLastPageRcdCount:=(RcdNumber mod RcdCountOfEachPageOfHengXiang);
        nPageNumber:=((RcdNumber-nLastPageRcdCount) div RcdCountOfEachPageOfHengXiang);
        nTmp:=RcdCountOfEachPageOfHengXiang;
      end;//
      //循环执行打印工作:
      for i:=1 to nPageNumber do
      begin
        try
          vSheet:=Open_Template;                 //打开模板
        except
          MyExcel.Quit;
          Exit;
        end;//
        TransferDataToExcel(FieldValues,BeginRow,BeginCol,FieldNumber,ntmp,IsNeedXuHao);    //数据输出到Excel
        try
          Print_PrintOut;            //从Excel中打印输出
        except
          ShowMessage('打印机错误,请检查你的打印机设备是否正常!');
          Exit;
        end;//
      end;//
      //执行剩余打印工作:
      if nLastPageRcdCount>0 then
      begin
        try
          vSheet:=Open_Template;
        except
          MyExcel.Quit;
          Exit;
        end;//
        TransferDataToExcel(FieldValues,BeginRow,BeginCol,FieldNumber,nLastPageRcdCount,IsNeedXuHao);
        try
          Print_PrintOut;
        except
          ShowMessage('打印机错误,请检查你的打印机设备是否正常!');
          Exit;
        end;//
      end;//
    end;

    {
    功能描述:释放Excel对象变量
    输入参数:无
    输出参数: 无
    创建时间:2006-04-07
    创建人:  赵占轻
    }
    destructor TExcel.Destroy;
    begin
      //
      inherited;
      MyExcel:=UnAssigned;
    end;

    {
    功能描述:使Excel程序关闭按钮失效
    输入参数:无
    输出参数:无
    创建时间:2006-04-18
    创建人:  刘惠城
    }
    procedure TExcel.DisableSystemCloseBox;
    var
      hExcelWindow : HWND;
      hSysMenu    : HMENU;
      nrlt:Integer;
    begin
      // Find the Excel2000 handle
      nrlt:=FindTheExcelMainWindow;
      if nrlt=0 then
      begin
        Exit;
      end
      else
      begin
        hExcelWindow:=MyWindowPtr.WinHandle;
      end;//
      if hExcelWindow <> 0 then
      begin
        hSysMenu := GetSystemMenu (hExcelWindow, false);
        EnableMenuItem (hSysMenu, SC_CLOSE, MF_DISABLED)
      end;
    end;
    //-------------------------------------------------------------------------//

    {
    功能描述:退出Excel
    输入参数:无
    输出参数:无
    创建时间:2003-11-09
    创建人:  徐伟亮
    }
    procedure TExcel.ExitExcel;
    begin
      try
        Book.Saved:=True;           //自动退出Excel时保存修改内容
      except
      end;
      MyExcel.Quit;
    end;

    {
    功能描述:辅助工程找出当前系统环境中的运行的excel的主窗体句柄
    输入参数:无
    输出参数:1:找到结果;0:未找到结果
    创建时间:2006-04-18
    创建人:  刘惠城
    }
    function TExcel.FindTheExcelMainWindow:Integer;//will alter
      function WindowCallback(WHandle : HWnd; Var Parm : Pointer) : Boolean; stdcall;
      {This function is called once for each window}
      Var MyString : PChar;
          MyInt : Integer;
          caption1:PChar;
      begin
        caption1:='Microsoft Excel';
        MyString := Allocmem(255);
        GetWindowText(WHandle,MyString,255);
        if StrPos(MyString,caption1)=nil then
        begin
          //FreeMem(caption1,16);
          Result := True;//Not find,continue to enumerate windows;
          Exit;
        end;//
        //
        {Window Handle (Passed by the enumeration)}
        MyWindowPtr.WinHandle := WHandle;
        {Window text}
        MyWindowPtr.WinCaption := String(MyString);
        FreeMem(MyString,255);

        {Process ID}
        MyInt := 0;
        MyWindowPtr.ProcessID := GetWindowThreadProcessId(WHandle,@MyInt);

        {Visiblity}
        MyWindowPtr.IsVisible := IsWindowVisible(WHandle);

        {Enabled}
        MyWindowPtr.IsEnabled := IsWindowEnabled(WHandle);

        {Iconic}
        MyWindowPtr.IsIconic := IsIconic(WHandle);

        {Window Dimensions}
        MyWindowPtr.WindowRect := Rect(0,0,0,0);
        GetWindowRect(WHandle,MyWindowPtr.WindowRect);
        //
        Result := False; {Everything's okay.Stop to enumerate windows}
      end;
      //
    begin
      //
      EnumWindows(@WindowCallback,0);
      if MyWindowPtr.WinHandle = 0 then
        begin
          Result:=0;
        end else
        begin
          Result:=1;
        end;
    end;

    {
    功能描述:获取模板路径
    输入参数:无
    输出参数:无
    创建时间:2006-04-11
    创建人:   赵占轻
    }
    function TExcel.Get_Template_Path: String;
    begin
      //
      Result:=Template_Path;
    end;

    {
    功能描述:控制是否出现警告存盘的对话框;
    输入参数:IsOrNo:控制是否显示提示框
                 (True:显示提示框;False:不显示提示框)
    输出参数:无
    创建时间:2006-04-07
    创建人:  赵占轻
    }
    procedure TExcel.IsAlert(IsOrNo: Boolean);
    begin
      MyExcel.DisplayAlerts:=IsOrNo;                 //是否出现警告存盘的对话框;
    end;

    {
    功能描述:控制是否显示Excel
    输入参数:IsOrNo:
              (True:显示Excel;False:不显示Excel)
    输出参数:无
    创建日期:2003-10-20
    创建人:  赵占轻
    }
    procedure TExcel.IsVisible(IsOrNo: Boolean);
    begin
      if IsOrNo then
      begin
        MyExcel.Visible:= True;
      end else
      begin
        MyExcel.Visible :=False;
      end;
    end;

    {
    功能描述:判断是否存在工作簿
    输入参数:无
    输出参数:0:不存在工作簿;1:存在工作簿
    创建时间:2006-04-07
    创建人:  赵占轻
    }
    function TExcel.IsWorkbookExit: Integer;
    var
      nBookCount:Integer;
    begin
      nBookCount:=MyExcel.Workbooks.Count;      //获取工作簿数量
      if nBookCount<=0 then
      begin
        Result:=0;
        Exit;
      end;//
      Result:=1;
    end;

    {
    功能描述:新建工作簿
    输入参数:无
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-14
    创建人:  赵占轻
    }
    function TExcel.New_WorkBook:Boolean;
    begin
      {在启动Excel之前,最好将以前运行的实例关闭
      因为有时会出现异常的情况;}
      //启动Excel应用程序:
      Result:=False;
      try
        if MyExcel.Workbooks.Count>=1 then             //如果Excel已经启动,
        begin                                      //且工作薄存在,则置
          Book:=MyExcel.Workbooks[1];                //第一个工作薄为当前
          Sheet:=MyExcel.Workbooks [1].Worksheets[1];//工作薄;
          Exit;
        end;//
        Book:=MyExcel.Workbooks.Add;
        if MyExcel.Worksheets.Count>=1 then
        begin
          Sheet:=Book.Worksheets.Item[1];
        end;
      except
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:打开模板
    输入参数:无
    输出参数:无
    创建时间:2006-04-11
    创建人:  赵占轻
    }
    function TExcel.Open_Template:Variant;
    var
      sTmp:String;
    begin
      //打开模板
      if MyExcel.Workbooks.Count>=1 then
      begin
        Book:=MyExcel.Workbooks[1];
        Book.Close;
      end;//
      sTmp:=Template_Path+Template_OpenName;
      Book:=MyExcel.Workbooks.Add (sTmp,0);
      Result:=MyExcel.Workbooks [1].Worksheets[1];
    end;

    {
    功能描述:打印页面设置
    输入参数:无
    输出参数:无
    创建时间:2006-04-11
    创建人:  赵占轻
    }
    procedure TExcel.Print_PageSetup;
    begin
      //打印设置
      IsPageSetup:=MyExcel.Dialogs.Item[xlDialogPageSetup].Show(
       EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam
      ,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam
      ,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam
      ,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam
      ,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam);
    end;

    {
    功能描述:打印输出
    输入参数:无
    输出参数:无
    创建时间:2006-04-11
    创建人:  赵占轻
    }
    procedure TExcel.Print_PrintOut;
    begin
      Sheet.PrintOut(EmptyParam);
    end;

    {
    功能描述:打印预览
    输入参数:无
    输出参数:无
    创建时间:2006-04-11
    创建人:  赵占轻
    }
    procedure TExcel.Print_PrintView;
    begin
      Sheet.PrintPreview;
    end;

    {
    功能描述:保存模板
    输入参数:无
    输出参数:无
    创建时间:2006-04-11
    创建人:  赵占轻
    }
    procedure TExcel.Save_Template;
    var
      sTmp:String;
    begin
      //保存模板
      sTmp:=Template_Path+Template_Name;
      Book.SaveAs(sTmp,xlTemplate);
    end;

    {
    功能描述:设置表的标题
    输入参数:TitleName    标题名称
              BeginRow     开始行
              BeginCol     开始列
              Row          所占用的行数
              Col          列数
              FontSize     字体大小
              IsNeedXuHao  是否需要序号
              IsNeedFrame  是否需要框架
    输出参数:无
    创建时间:2003-10-20
    创建人:  赵占轻
    }
    procedure TExcel.SetTableTitle(TitleName: String;
                                   BeginRow,BeginCol,Row, Col,FontSize: integer;
                                   IsNeedXuHao:Boolean=False;IsNeedFrame:Boolean=True);
    var
      vRange,vCell1,vCell2:Variant;
      nCol,nRow:Integer;
      sTitleName:String;
    begin
      sTitleName:=TitleName;                      //记录标题名
      nCol:=Col;                                    //记录标题所占用的列数
      nRow:=Row;                                    //记录标题所占用的行数
      vCell1:=Sheet.Cells[BeginRow,BeginCol];        //记录起始单元格
      if IsNeedXuHao then                           //需要序号
      begin
        MergeCells(BeginRow,BeginCol,nRow,nCol+1);               //合并单元格
        SetRangeHorizontalAlignment(BeginRow,BeginCol,nRow,nCol+1,xlHAlignCenter);//水平对其方式为居中
        SetRangeVerticalAlignment(BeginRow,BeginCol,nRow,nCol+1,xlVAlignCenter); //垂直对其方式为居中
        //设置字体样式
        SetRangeFontStyle(BeginRow,BeginCol,nRow,nCol+1,'正常','宋体',5,FontSize);         //设置指定范围的字体样式
        SetRangeValue(BeginRow,BeginCol,nRow,nCol+1,sTitleName);     //设置标题
        if IsNeedFrame then                           //需要边框
        begin
          SetRangeOutBorderStyle(BeginRow,BeginCol,nRow,nCol,1,0,1);
        end;  
      end
      else                                          //不需要序号
      begin
        MergeCells(BeginRow,BeginCol,nRow,nCol);               //合并单元格
        SetRangeHorizontalAlignment(BeginRow,BeginCol,nRow,nCol,xlHAlignCenter);//水平对其方式为居中
        SetRangeVerticalAlignment(BeginRow,BeginCol,nRow,nCol,xlVAlignCenter); //垂直对其方式为居中
        //设置字体样式
        SetRangeFontStyle(BeginRow,BeginCol,nRow,nCol,'正常','宋体',5,FontSize);         //设置指定范围的字体样式
        SetRangeValue(BeginRow,BeginCol,nRow,nCol,sTitleName);
        if IsNeedFrame then                           //需要边框
        begin
          SetRangeOutBorderStyle(BeginRow,BeginCol,nRow,nCol,1,0,1);
        end;  
      end;
    end;

    {
    功能描述:设置Excel工作表中的列名
    输入参数: AFields      列名列表
              BeginRow     起始行号
              BeginCol     起始列号
              FieldNumber  列数
              IsNeedXuHao  是否需要序号
    输出参数:无
    创建时间:2006-04-13
    创建人:  赵占轻
    }
    procedure TExcel.SetTheFieldsName(AFields:TStringList;BeginRow,BeginCol,FieldNumber:Integer;IsNeedXuHao:Boolean);
    var
      vRange,vCell1,vCell2:Variant;
      nCol,i,j:Integer;
      sValue:String;
    begin
      nCol:=BeginCol+FieldNumber-1;
      //从数据库中读出字段名并输出到第一列:
      vCell1:=Sheet.Cells[BeginRow,BeginCol];
      vCell2:=Sheet.Cells[BeginRow,nCol];
      vRange:=Sheet.Range[vCell1,vCell2];
    //  SetRangeFontStyle(vRange,'常规','宋体',5,13);      //设置指定范围的字体样式
      if IsNeedXuHao then
      begin
        Sheet.Cells[BeginRow,BeginCol]:='序号';
        for i:=BeginCol to FieldNumber do
        begin
          sValue:=AFields[i-1];
          Sheet.Cells[BeginRow,i+1]:=sValue;
          Sheet.Cells[BeginRow,i+1].Borders.LineStyle:=1;
        end;
        exit;
      end;
      //-----------------------------------------//
      j:=0;
      for i:=BeginCol to FieldNumber+BeginCol-1 do
        begin
          sValue:=AFields[j];
          Sheet.Cells[BeginRow,i].Borders.LineStyle:=1;
          Sheet.Cells[BeginRow,i]:=sValue;
          Sheet.Cells[BeginRow,i].HorizontalAlignment:= xlHAlignCenter;
          Sheet.Cells[BeginRow,i].VerticalAlignment:=xlVAlignCenter;
          j:=j+1;
        end;
    end;

    {
    功能描述:设置打开模板的名称
    输入参数: TemplateName:模板名称
    输出参数:无
    创建时间:2006-04-11
    创建人:  赵占轻
    }
    procedure TExcel.Set_Template_OpenName(TemplateName: String);
    begin
      //
      Template_OpenName:=TemplateName;
    end;

    {
    功能描述:设置模板路径
    输入参数:PathName:路径名
    输出参数:无
    创建时间:2006-04-11
    创建人:  赵占轻
    }
    procedure TExcel.Set_Template_Path(PathName: String);
    begin
      //
      Template_Path:=PathName;
    end;

    {
    功能描述:转换数据到Excel
    输入参数:FieldValues  字段值列表
              BeginRow     起始行号
              BeginCol     起始列号
              FieldNumber  字段数
              RcdNumber    记录数
              IsNeedXuHao  是否需要序号
    输出参数:无
    创建时间:2006-04-13
    创建人:  赵占轻
    }
    procedure TExcel.TransferDataToExcel(FieldValues:Array of TStringList; BeginRow, BeginCol,
      FieldNumber,RcdNumber: Integer; IsNeedXuHao: Boolean);
    var
      i,j,nSerial:Integer;
      sValue:String;
    begin
      //
      //设置序号值:
      if IsNeedXuHao then
      begin
        nSerial:=1;
        for i:=BeginRow to BeginRow+RcdNumber do                             //
        begin
           //
          Sheet.Cells[i,BeginCol].Borders.LineStyle:=1;
          Sheet.Cells[i,BeginCol]:=nSerial;
          Sheet.Cells[i,BeginCol].HorizontalAlignment:= xlHAlignCenter;
          Sheet.Cells[i,BeginCol].VerticalAlignment:=xlVAlignCenter;
          //
          if i=BeginRow+RcdNumber-1 then
          begin
            break;
          end;//
          nSerial:=nSerial+1;
        end;//
        BeginCol:=BeginCol+1;
      end;//
      // 传输数据到Excel工作表
      for i:=0 to RcdNumber-1 do
      begin
        for j:=0 to FieldNumber-1 do
        begin
          sValue:=FieldValues[i][j] ;
          Sheet.Cells[BeginRow+i,BeginCol+j].Borders.LineStyle:=1;
          Sheet.Cells[BeginRow+i,BeginCol+j]:=sValue;
          Sheet.Cells[BeginRow+i,BeginCol+j].HorizontalAlignment:= xlHAlignCenter;
          Sheet.Cells[BeginRow+i,BeginCol+j].VerticalAlignment:=xlVAlignCenter;
        end;//
      end;//
    end;

    {
    功能描述:得到当前工作表中某行某列的值
    输入参数:Row:指定行号;
              Col:指定单元格列号
    输出参数:返回指定单元格的值
    创建时间:2006-04-11
    创建人:  赵占轻
    }
    function TExcel.GetCell(Row,Col:Integer):Variant;
    begin
      if (Row=0) or (Col=0) then
      begin
        Result:=-1;
        Exit;
      end;
      Result:=Sheet.Cells[Row,Col];
    end;

    {
    功能描述:对指定单元格间的值求和
    输入参数:BeginRow   起始单元格的行号
              BeginCol   起始单元格的列号
              EndRow     终止单元格的行号
              EndCol     终止单元格的列号
    输出参数:返回总和值
    创建时间:2006-04-11
    创建人:  赵占轻
    }
    function TExcel.Sum(BeginRow,BeginCol,EndRow,EndCol:Integer):Double;
    var
      dTotal:Double;
      vRange,vCell1,vCell2:Variant;
    begin
      vCell1:=Sheet.Cells[BeginRow,BeginCol];          //获取起始单元格
      vCell2:=Sheet.Cells[EndRow,EndCol];              //获取终止单元格
      vRange:=MyExcel.Range[vCell1,vCell2];
      //计算总和
      dTotal:=MyExcel.Sum (vRange,vRange,EmptyParam,EmptyParam
      ,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam
      ,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam
      ,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam
      ,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam,EmptyParam
      ,EmptyParam,EmptyParam);

      //
      Result:=dTotal/2.0;
    end;//

    {
    功能描述:设置指定单元格的值
    输入参数:Value: 设置的单元格的值
              Row:  指定单元格的行号
              Col:   指定单元格的列号
              AType:单元格值的类型  (0:字符型;1:整形;2,3:数值型)
    输出参数:无
    创建时间:2006-04-11
    创建人:  赵占轻
    }
    procedure TExcel.SetCell(Value: String; Row, Col: Integer;AType:Integer);
    begin
      case AType of
        0: //字符型
          begin
            //格式化单元格为文本样式,确保数据格式正确
            Sheet.Cells[Row,Col].NumberFormatLocal:='@';
          end;
        1:  //整型
          begin
            Sheet.Cells[Row,Col].NumberFormatLocal:='0';
          end;
        2:
          begin
            //格式化单元格为文本样式,确保数据格式正确
            Sheet.Cells[Row,Col].NumberFormatLocal:='0.00000';
          end;
        3: //浮点型
          begin
            Sheet.Cells[Row,Col].NumberFormatLocal:='0.00000';
          end;
      end;
      Sheet.Cells[Row,Col]:=Value;
    end;

    {
    功能描述:设置单元格为自动列宽
    输入参数:无
    输出参数:无
    创建时间:2003-11-20
    创建人:  赵占轻
    }
    procedure TExcel.CellAutoFit;
    begin
      MyExcel.Columns.AutoFit;
    end;

    {
    功能描述: 打开指定的Excel文件
    输入参数: FileName:要打开的文件名   如:c:\test.xls
    输出参数: 执行成功返回真否则返回假
    创建时间: 2006-04-07
    设计人:   赵占轻
    }
    function TExcel.OpenExcelFile(FileName: string): Boolean;
    begin
      Result:=False;
      try
        Book:=MyExcel.Workbooks.Open(FileName);
        Sheet:=Book.WorkSheets.Item[1];
      except
        Exit;
      end;
      Result:=True;
    end;


    {
    功能描述:    得到指定的工作表
    输入参数:    SheetNum:工作表顺序号;ASheet:记录获取的工作表
    输出参数:    执行成功返回真否则返回假
    输入输出参数:ASheet:返回获取的工作表
    创建时间:    2006-04-11
    创建人:       赵占轻
    }

    {
    功能描述:获取当前活动工作簿中指定工作表的工作范围
    输入参数:ASheet:要操作的工作表;SheetNum:指定工作簿中工作表的序号
    输出参数:工作区地址字符串 如"A1:Z200"
    创建时间: 2006-04-07
    创建人:   赵占轻
    }
    function TExcel.GetSheetRange:string;
    var
      sTemp:String;
      i:Integer;
    begin
      sTemp:=Sheet.UsedRange.AddressLocal;                //取指定工作表中的工作范围
      //分析字符串提取行列号
      for i:=1 to Length(sTemp) do
      begin
        if sTemp[i]<>'$' then
        begin
          Result:=Result+sTemp[i];
        end;
      end;
      if Pos(':',ReSult)=0 then
      begin
        UsedRowBeg:=GetRowNum(ReSult);  //起始行号
        UsedColBeg:=GetColNum(Result);  //起始列号
        UsedRowEnd:=UsedRowBeg;           //终止行号
        UsedColEnd:=UsedColBeg;           //终止列号
        Result:=Result+':'+Result;
      end
      else
      begin
        sTemp:=Copy(Result,1,Pos(':',Result)-1);
        UsedRowBeg:=GetRowNum(sTemp); //起始行号
        UsedColBeg:=GetColNum(sTemp); //其实列号
        sTemp:=Copy(Result,Pos(':',Result)+1,Length(Result)-Pos(':',Result));
        UsedRowEnd:=GetRowNum(sTemp);  //终止行号
        UsedColEnd:=GetColNum(sTemp);  //终止列号
      end;
    end;

    {
    功能描述:获取指定单元格的列号
    输入参数: TStr:单元格地址
    输出参数: 单元格列号
    创建时间: 2006-04-07
    创建人:   赵占轻
    }
    function TExcel.GetColNum(TStr:string):Integer;
    begin
      Result:=StrToInt(Sheet.Range[TStr].Cells.Column);
    end;

    {
    功能描述:获取指定单元格的行号
    输入参数: TStr:单元格地址
    输出参数: 单元格行号
    创建时间: 2006-04-07
    创建人:   赵占轻
    }
    function TExcel.GetRowNum(TStr:string):Integer;
    begin
      Result:=StrToInt(Sheet.Range[TStr].Cells.Row);
    end;

    {
    功能描述:    得到当前工作簿中所有工作表名称
    输入参数:    FileName:用于返回获取的所有工作表名称
    输出参数:    操作结果 True:执行成功;False: 执行失败
    输入输出参数:FileName:用于返回获取的所有工作表名称
    创建时间:    2003-10-24
    创建人:      赵占轻
    }
    function TExcel.GetSheetsNameList(var FileName:TstringList):Boolean;
    var
      i:Integer;
      vSheet:Variant;
    begin
      try
        for i:=1 to MyExcel.ActiveWorkbook.Sheets.Count do
        begin
          vSheet:=MyExcel.ActiveWorkbook.Worksheets[i];       //获取第i个工作表
          FileName.Add(VSheet.Name);                          //记录第i个工作表的名称
        end;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:合并单元格
    输入参数:ABegRowNum:  待合并单元格的起始行号
              ABegColNum:   起始列号
              AEndRowNum:  终止行号
              AEndColNum:  终止列号
    输出参数: 返回合并后的单元格
    创建时间: 2006-04-11
    创建人:  赵占轻
    }
    function  TExcel.MergeCells(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer):Variant;           //合并单元格
    var
      vRange:Variant;
      vBegCell,vEndCell:Variant;
    begin
      try
        vBegCell:=Sheet.Cells[ABegRowNum,ABegColNum];
        vEndCell:=Sheet.Cells[AEndRowNum,AEndColNum];
        vRange:=Sheet.Range[vBegCell,vEndCell];              //获取指定单元格间的范围
        vRange.Merge;                                  //合并单元格
        Result:=vRange;
      except
        Result:=Null;
      end;
    end;

    {
    功能描述:设置指定范围单元格的字体样式
    输入参数:BeginRow    指定范围的起始单元格行号;
              BeginCol    指定范围的起始单元格列号;
              EndRow      指定范围的终止单元格行号
              EndCol      指定范围的终止单元格列号
              AFontStyle  目标字体样式(如粗体);
              AFontName   目标字体名称;
              AFontSize   目标字体大小
              AFontColor  目标字体颜色
    输出参数:执行成功返回真;否则返回假
    创建时间:2006-04-12
    创建人:  赵占轻
    }
    function TExcel.SetRangeFontStyle(BeginRow,BeginCol,EndRow, EndCol:Integer;
                                    AFontStyle:string='常规';AFontName:string='宋体';
                                    AFontColor:Integer=0;AFontSize:Integer=12):Boolean;  //设置范围  
    var
      vRange:Variant;
      vBegCel,vEndCell:Variant;
    begin
      try
        vBegCel:=Sheet.Cells[BeginRow,BeginCol];
        vEndCell:=Sheet.Cells[EndRow, EndCol];
        vRange:=Sheet.Range[vBegCel,vEndCell];
        vRange.Font.ColorIndex:=AFontColor;                 //设置字体颜色
        vRange.Font.Name:=AFontName;                        //设置字体名称
        vRange.Font.Size:=AFontSize;                        //设置字体大小
        vRange.Font.FontStyle:=AFontStyle;                  //设置字体样式
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置指定范围的外边框样式
    输入参数:ABegRowNum    待设置范围的起始行号
              ABegColNum    待设置范围的起始列号
              AEndRowNum    待设置范围的终止行号
              AEndColNum    待设置范围的终止列号
              AWeight       边线粗度
              ALineColor    边线颜色
              ALineStyle    边线样式
              
    输出参数:执行成功返回真否则返回假
    创建时间:2006-05-08
    创建人:  赵占轻
    }
    function TExcel.SetRangeOutBorderStyle(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer;
                                     AWeight:Integer=2;ALineColor:Integer=0;ALineStyle:Integer=xlContinuous):Boolean;
    var
      vBegCell,vEndCell:Variant;
      vRange:Variant;
    begin
      vBegCell:=Sheet.Cells[ABegRowNum,ABegColNum];
      vEndCell:=Sheet.Cells[AEndRowNum,AEndColNum];
      vRange:=Sheet.Range[vBegCell,vEndCell];
      try
        //设置左边框
        vRange.Borders.Item[xlEdgeLeft].LineStyle :=ALineStyle;
        vRange.Borders.Item[xlEdgeLeft].Weight := AWeight;
        vRange.Borders.Item[xlEdgeLeft].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      try
        //设置顶边框
        vRange.Borders.Item[xlEdgeTop].LineStyle := ALineStyle;
        vRange.Borders.Item[xlEdgeTop].Weight := AWeight;
        vRange.Borders.Item[xlEdgeTop].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      try
        //设置底边框
        vRange.Borders.Item[xlEdgeBottom].LineStyle := ALineStyle;
        vRange.Borders.Item[xlEdgeBottom].Weight := AWeight;
        vRange.Borders.Item[xlEdgeBottom].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      try
        //设置右边框
        vRange.Borders.Item[xlEdgeRight].LineStyle := ALineStyle;
        vRange.Borders.Item[xlEdgeRight].Weight := AWeight;
        vRange.Borders.Item[xlEdgeRight].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置指定范围的分隔线样式
    输入参数:ABegRowNum   待设置范围的起始行号
              ABegColNum   待设置范围的起始列号
              AEndRowNum   待设置范围的终止行号
              AEndColNum   待设置范围的终止列号
              AWeight      分割线粗度
              ALineColor   分割线颜色
              ALineStyle   分割线样式
              
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-13
    创建人:  赵占轻
    }
    function  TExcel.SetRangeInnerLineStyle(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer;
                       AWeight:Integer=2;ALineColor:Integer=0;ALineStyle:Integer=xlContinuous):Boolean;        //设置指定范围的分隔线样式
    var
      vBegCell,vEndCell:Variant;
      vRange:Variant;
    begin
      vBegCell:=Sheet.Cells[ABegRowNum,ABegColNum];
      vEndCell:=Sheet.Cells[AEndRowNum,AEndColNum];
      vRange:=Sheet.Range[vBegCell,vEndCell];
      try
        //设置垂直线样式
        vRange.Borders.Item[xlInsideVertical].LineStyle :=ALineStyle;
        vRange.Borders.Item[xlInsideVertical].Weight := AWeight;
        vRange.Borders.Item[xlInsideVertical].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      try
        //设置水平线样式
        vRange.Borders.Item[xlInsideHorizontal].LineStyle := ALineStyle;
        vRange.Borders.Item[xlInsideHorizontal].Weight := AWeight;
        vRange.Borders.Item[xlInsideHorizontal].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置当前工作表,并将指定的工作表存储到类属性Sheet中供其他操作使用
    输入参数:待指定的工作表的序号
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-13
    创建人:  赵占轻
    }
    function TExcel.SetCurrentSheet(SheetNum:Integer):Boolean;             //设置当前工作簿
    begin
      Result:=False;
      try
        Sheet:=MyExcel.Worksheets.Item[SheetNum];
        Result:=True;
      except
      end;
    end;

    {
    功能描述:设置范围的水平对其方式
    输入参数:ABegRowNum   待设置的范围的起始行号
              ABegColNum   待设置的范围的起始列号
              AEndRowNum   待设置的范围的终止行号
              AEndColNum   待设置的范围的终止列号
              AAlign       对其方式
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-13
    创建人:  赵占轻
    }
    function TExcel.SetRangeHorizontalAlignment(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer;AAlign:Integer=xlLeft):Boolean;
    var
      vBegCell,vEndCell:Variant;
      vRange:Variant;
    begin
      try
        vBegCell:=Sheet.Cells[ABegRowNum,ABegColNum];
        vEndCell:=Sheet.Cells[AEndRowNum,AEndColNum];
        vRange:=Sheet.Range[vBegCell,vEndCell];
        vRange.HorizontalAlignment:= AAlign;   //水平对其方式为居中
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置范围的垂直对其方式
    输入参数:ABegRowNum          待设置的范围起始行号
              ABegColNum          待设置的范围起始列号
              AEndRowNum          待设置的范围终止行号
              AEndColNum          待设置的范围终止列号
              AAlign              对其方式
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-13
    创建人:  赵占轻
    }
    function TExcel.SetRangeVerticalAlignment(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer;AAlign:Integer=xlBottom):Boolean;  //设置范围的垂直对其方式
    var
      vBegCell,vEndCell:Variant;
      vRange:Variant;
    begin
      try
        vBegCell:=Sheet.Cells[ABegRowNum,ABegColNum];
        vEndCell:=Sheet.Cells[AEndRowNum,AEndColNum];
        vRange:=Sheet.Range[vBegCell,vEndCell];
        vRange.VerticalAlignment:= AAlign;   //垂直对其方式为居中
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:对指定的工作表进行页面设置
    输入参数:APageType:       纸张类型;
              Orientation:      页面方向(横向或纵向)
              LeftMargin:      左边距
              RightMargin:     右边距
              TopMargin:       上边距
              BottomMargin:    下边距
              HeaderMargin:    页眉到顶端边距
              FooterMargin:     页脚到底端边距
              
    输出参数:执行成功返回真否则返回假
    创建时间: 2006-04-18
    创建人:  赵占轻
    }
    function TExcel.SetSheetPage(APageType,Orientation:Integer;LeftMargin,RightMargin,
             TopMargin,BottomMargin,HeaderMargin,FooterMargin:Double):Boolean;
    begin
      try
        //页面设置
        Sheet.PageSetup.PaperSize := APageType;   //     设定纸张
        Sheet.PageSetup.Orientation := Orientation;//     横向纸张
        //设定页边距
        Sheet.PageSetup.LeftMargin := MyExcel.InchesToPoints(LeftMargin);
        Sheet.PageSetup.RightMargin := MyExcel.InchesToPoints(RightMargin);
        Sheet.PageSetup.TopMargin := MyExcel.InchesToPoints(TopMargin);
        Sheet.PageSetup.BottomMargin := MyExcel.InchesToPoints(BottomMargin);  //1cm
        Sheet.PageSetup.HeaderMargin := MyExcel.InchesToPoints(HeaderMargin);
        Sheet.PageSetup.FooterMargin := MyExcel.InchesToPoints(FooterMargin);
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置指定列的宽度
    输入参数:AColNum:   待设置的列的列号
              AColWidth:目标列宽
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-13
    创建人:  赵占轻
    }
    function TExcel.SetColumnWidth(AColNum:Integer;AColWidth:Double):Boolean;
    begin
      try
        Sheet.Columns[AColNum].ColumnWidth:=AColWidth;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;

    end;

    {
    功能描述:设置指定范围内单元格的列宽
    输入参数:ABeginRow  指定范围的起始行号
              ABeginCol  指定范围的起始列号
              AEndRow    指定范围的终止行号
              AEndCol    指定范围的终止列号
              AColWidth:列宽
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.SetRangeColWidth(ABeginRow,ABeginCol,AEndRow,AEndCol:Integer;AColWidth:Double):Boolean;
    var
      vRange,vBeginCell,vEndCell:Variant;
    begin
      try
        vBeginCell:=Sheet.Cells[ABeginRow,ABeginCol];
        vEndCell:=Sheet.Cells[AEndRow,AEndCol];
        vRange:=Sheet.Range[vBeginCell,vEndCell];
        vRange.ColumnWidth:=AColWidth;
     except
       Result:=False;
       Exit;
     end;
     Result:=True;
    end;

    {
    功能描述:绘制平断面图时根据不同情况格式化单元格
    输入参数:APage      当前页号
              AColNum    列数
              ARow       行号
              AColName   列名
              AValueList 待填充的值的列表
    输出参数:无
    创建时间:2006-04-18
    创建人:  赵占轻
    }
    procedure TExcel.FormatCells(APage, AColNum, ARow: Integer;AColName: String;AValueList: TStringList);
    var
      nBegRow,nEndRow:Double;
      i: Integer;
      sValue: String;
      nIndex: Integer;
      dX,dY: Double;
      dX1, dY1: Double;
      nPageTop:Integer;
      dAngle: Double;
      dOldY2: Double;
      dGanGao: Double;
      bIsFirstPole, bIsTJPole: Boolean;
      bIsCable: Boolean;
    begin
      dAngle:=0;
      nPageTop := (APage-1)*pm_PageRows;        //每页行数
      //处理行高
      case ARow of
        6, 13:
          begin
            //情况特殊,需要加高
            Sheet.Rows[nPageTop+ARow].RowHeight := 28;
          end;
        18:
          begin
            //情况特殊,需要加高
            Sheet.Rows[nPageTop+ARow].RowHeight := 33;
          end;
        else
          begin
            Sheet.Rows[nPageTop+ARow].RowHeight := 15;
          end;
      end;
      //列头
      MergeCells(nPageTop+ARow,1,nPageTop+ARow,2);
      SetRangeOutBorderStyle(nPageTop+ARow,1,nPageTop+ARow,2,1,0,1);
      SetRangeFontStyle(nPageTop+ARow,1,nPageTop+ARow,2,'常规','宋体',1,11);
      SetRangeHorizontalAlignment(nPageTop+ARow,1,nPageTop+ARow,2,xlCenter);
      SetRangeVerticalAlignment(nPageTop+ARow,1,nPageTop+ARow,2,xlCenter);
      SetRangeValue(nPageTop+ARow,1,nPageTop+ARow,2,AColName);
      if (ARow = 10)or(ARow = 11)or(ARow = 13) then        //档距和累计长度特殊
      begin
        //合并第一个格
        SetRangeOutBorderStyle(nPageTop+ARow,3,nPageTop+ARow,3,1,0,1);
        SetRangeFontStyle(nPageTop+ARow,3,nPageTop+ARow,3,'常规','宋体',1,11);
        SetRangeHorizontalAlignment(nPageTop+ARow,3,nPageTop+ARow,3,xlCenter);
        SetRangeVerticalAlignment(nPageTop+ARow,3,nPageTop+ARow,3,xlCenter);

        nIndex := (APage-1)*AColNum;
        if nIndex <= AValueList.Count -1 then    //防止数据溢出
        begin
          case ARow of
            10: sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.DJ;
            11: sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.LJCD;
            13: SValue := PRecData(Integer(AValueList.Objects[nIndex]))^.JCKY;
          end;
          if sValue <> '0' then
          begin
            SetRangeValue(nPageTop+ARow,3,nPageTop+ARow,3,sValue);
          end;
        end;
        //合并最后一个格
        SetRangeOutBorderStyle(nPageTop+ARow,24,nPageTop+ARow,24,1,0,1);
        SetRangeFontStyle(nPageTop+ARow,24,nPageTop+ARow,24,'常规','宋体',1,11);
        SetRangeHorizontalAlignment(nPageTop+ARow,24,nPageTop+ARow,24,xlCenter);
        SetRangeVerticalAlignment(nPageTop+ARow,24,nPageTop+ARow,24,xlCenter);
        //处理列
        for i := 0 to 9 do
        begin
          MergeCells(nPageTop+ARow,i*2+4,nPageTop+ARow,i*2+5);
          SetRangeOutBorderStyle(nPageTop+ARow,i*2+4,nPageTop+ARow,i*2+5,1,0,1);
          SetRangeFontStyle(nPageTop+ARow,i*2+4,nPageTop+ARow,i*2+5,'常规','宋体',1,11);
          SetRangeHorizontalAlignment(nPageTop+ARow,i*2+4,nPageTop+ARow,i*2+5,xlCenter);
          SetRangeVerticalAlignment(nPageTop+ARow,i*2+4,nPageTop+ARow,i*2+5,xlCenter);
          nIndex := (APage-1)*AColNum+i+1;
          if nIndex <= AValueList.Count -1 then    //防止数据溢出
          begin
            case ARow of
              10: sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.DJ;
              11: sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.LJCD;
              13:
                begin
                  sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.JCKY;
                  SetRangeAutoWrap(nPageTop+ARow,i*2+4,nPageTop+ARow,i*2+5);//自动换行
               end;
            end;
            if sValue <> '0' then
            begin
              Self.SetRangeValue(nPageTop+ARow,i*2+4,nPageTop+ARow,i*2+5,sValue);
            end;
          end;
        end;
        Exit;
      end;
      //普通情况
      for i := 0 to 10 do
      begin
        MergeCells(nPageTop+ARow,i*2+3,nPageTop+ARow,i*2+4);
        SetRangeOutBorderStyle(nPageTop+ARow,i*2+3,nPageTop+ARow,i*2+4,1,0,1);
        SetRangeFontStyle(nPageTop+ARow,i*2+3,nPageTop+ARow,i*2+4,'常规','宋体',1,10);
        SetRangeHorizontalAlignment(nPageTop+ARow,i*2+3,nPageTop+ARow,i*2+4,xlCenter);
        SetRangeVerticalAlignment(nPageTop+ARow,i*2+3,nPageTop+ARow,i*2+4,xlCenter);
        nIndex := (APage-1)*AColNum + i;
        if nIndex <= AValueList.Count -1 then
        begin
          case ARow of
            5:
              begin
                sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.GH;

                if PRecData(Integer(AValueList.Objects[nIndex]))^.GG <> '' then
                begin
                  dGanGao := StrToFloat(PRecData(Integer(AValueList.Objects[nIndex]))^.GG);
                end
                else begin
                  dGanGao := 10;
                end;
                if i = 0 then
                begin
                  if PRecData(Integer(AValueList.Objects[nIndex]))^.IsTJPole =1 then
                  begin
                    bIsTJPole := True;
                    bIsFirstPole := True;
                  end
                  else begin
                    bIsFirstPole := True;
                    bIsTJPole := False;
                  end;
                end
                else begin
                  bIsFirstPole := False;
                  bIsTJPole := False;
                end;
                if PRecData(Integer(AValueList.Objects[nIndex]))^.IsCable = 1 then
                begin
                  bIsCable := True;   //是电缆
                end
                else begin
                  bIsCable := False;   //不是电缆
                end;

                GetCellDMGanCoord(APage, i+1, dX1, dY1);
                //画断面图
                CreateDMT( dX1, dY1, dGanGao, bIsTJPole, bIsFirstPole, bIsCable, dOldY2);

                //画分支
                if PRecData(Integer(AValueList.Objects[nIndex]))^.FZ1ZJ <> '' then
                begin
                  dAngle := StrToFloat(PRecData(Integer(AValueList.Objects[nIndex]))^.FZ1ZJ);
                  //画分支
                  GetCellGanCoord(APage, i+1, dX, dY);
                  CreateFZLine(dX, dY,0,dAngle, PRecData(Integer(AValueList.Objects[nIndex]))^.FZ1MC);
                end;
                if PRecData(Integer(AValueList.Objects[nIndex]))^.FZ2ZJ <> '' then
                begin
                  GetCellGanCoord(APage, i+1, dX, dY);
                  if dAngle >= 0 then
                  begin
                    if StrToFloat(PRecData(Integer(AValueList.Objects[nIndex]))^.FZ2ZJ)>=0 then
                    begin
                      //画分支 线路名同向
                      CreateFZLine(dX, dY, 14, StrToFloat(PRecData(Integer(AValueList.Objects[nIndex]))^.FZ2ZJ), PRecData(Integer(AValueList.Objects[nIndex]))^.FZ2MC);
                    end
                    else begin
                      CreateFZLine(dX, dY,0, StrToFloat(PRecData(Integer(AValueList.Objects[nIndex]))^.FZ2ZJ), PRecData(Integer(AValueList.Objects[nIndex]))^.FZ2MC);
                    end;
                  end
                  else begin
                    if StrToFloat(PRecData(Integer(AValueList.Objects[nIndex]))^.FZ2ZJ)<0 then
                    begin
                      //画分支 线路名同向
                      CreateFZLine(dX, dY, -14, StrToFloat(PRecData(Integer(AValueList.Objects[nIndex]))^.FZ2ZJ), PRecData(Integer(AValueList.Objects[nIndex]))^.FZ2MC);
                    end
                    else begin
                      CreateFZLine(dX, dY,0, StrToFloat(PRecData(Integer(AValueList.Objects[nIndex]))^.FZ2ZJ), PRecData(Integer(AValueList.Objects[nIndex]))^.FZ2MC);                end;
                  end;
                end;
              end;
            6:
              begin
                sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.GX;
                SetRangeAutoWrap(nPageTop+ARow,i*2+3,nPageTop+ARow,i*2+4);//自动换行
              end;
            7: sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.GG;
            8: sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.MS;
            9: sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.DXXH;
            12:
              begin
                Self.SetRangeFontStyle(nPageTop+ARow,i*2+3,nPageTop+ARow,i*2+4,'常规','宋体',0,9);
                if PRecData(Integer(AValueList.Objects[nIndex]))^.ZJ <> '' then
                begin
                  //画转角
                  GetCellGanCoord(APage, i+1, dX, dY);
                  CreateArrowheadLine(dX, dY, StrToFloat(PRecData(Integer(AValueList.Objects[nIndex]))^.ZJ));
                end;
                sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.ZJ;
                if sValue <> '' then
                begin
                  sValue := DoubleToFenMiao(Abs(StrToFloat(sValue)));
                end;
              end;
            14: sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.CZJL;
            15: sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.HDGG;
            16: sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.LXWZ;
            17: sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.LXXHGS;
            18:
              begin
                sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.JYZXHSL;
                SetRangeAutoWrap(nPageTop+ARow,i*2+3,nPageTop+ARow,i*2+4);//自动换行
              end;
            19: //变台
              begin
                if i <> 0 then
                begin
                  GetCellGanCoord(APage, i, dX1, dY1);   //上一个点坐标
                  GetCellGanCoord(APage, i+1, dX, dY);   //当前点坐标
                  if PRecData(Integer(AValueList.Objects[nIndex]))^.BTXS <> '' then
                  begin
                    if PRecData(Integer(AValueList.Objects[nIndex-1]))^.BTXS <> '' then
                    begin
                      //前一棵杆有变压器
                      //画线
                      Sheet.Shapes.AddLine(dX1+pm_BYQD-2, dY1, dX-pm_BYQD+2, dY).Select;
                    end
                    else begin
                      //前一棵杆无变压器
                     Sheet.Shapes.AddLine(dX1, dY1, dX-pm_BYQD+2, dY).Select;
                    end;
                  end
                  else begin
                    if PRecData(Integer(AValueList.Objects[nIndex-1]))^.BTXS <> '' then
                    begin
                      //画线
                      Sheet.Shapes.AddLine(dX1+pm_BYQD-2, dY1, dX, dY).Select;
                    end
                    else begin
                      Sheet.Shapes.AddLine(dX1, dY1, dX, dY).Select;
                    end;
                  end;
                  MyExcel.Selection.ShapeRange.ZOrder(msoSendToBack);
                end;
                if PRecData(Integer(AValueList.Objects[nIndex]))^.BTXS <> '' then
                begin
                  //画变台
                  GetCellGanCoord(APage, i+1, dX, dY);
                  DrawBYQ(dX, dY);
                  DrawBYQText(dX, dY, PRecData(Integer(AValueList.Objects[nIndex]))^.HM);
                end
                else begin
                  //画杆
                  Sheet.Shapes.AddShape(msoShapeOval, pm_GanFirstLeft+(i*pm_GanOffset), (APage-1)*V_PageOffset+pm_GanTop, pm_GanD, pm_GanD);
                end;
                sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.BTXS;
              end;
            20: sValue := PRecData(Integer(AValueList.Objects[nIndex]))^.PBRL;
          end;
        end
        else begin
          //为了填补空格
          sValue := '';
        end;
        if sValue <> '' then
        begin
          SetRangeValue(nPageTop+ARow,i*2+3,nPageTop+ARow,i*2+4,sValue);//自动换行
        end;
      end;

    end;

    {
    //功能描述:创建页
    //输入参数:APage       当前页号
                ABDZMC      变电站名称
                AXLMC       线路名称
                AValueList  要输入的数据值列表
    //输出参数:无
    //创建时间:2006-04-14
    //创建人:  赵占轻
    }
    procedure TExcel.CreatePage(APage: Integer;ABDZMC, AXLMC: String;AValueList: TStringList);
    var
      sGDSMC: String;
      nColNum: Integer;
      sColName: String;
      nPageTop: Integer;
      AFontColor: TColor;
      nRow: Integer;
      i: Integer;
    begin
      sGDSMC := '城关供电所';
      nColNum := 11;                   //字段列数
      nPageTop := (APage-1)*pm_PageRows;        //每页行数
      AFontColor := 1;
      //处理第1行数据   标题
      nRow := 1;
      SetRowHeight(nPageTop+nRow,20.25);
      //设定合并单元格
      MergeCells(nPageTop+nRow,1,nPageTop+nRow,24);
      SetRangeFontStyle(nPageTop+nRow,1,nPageTop+nRow,24,'粗体','宋体',AFontColor,16);  //设置指定区域中字体样式
      SetRangeHorizontalAlignment(nPageTop+nRow,1,nPageTop+nRow,24,xlCenter);           //设置水平对齐方式
      SetRangeVerticalAlignment(nPageTop+nRow,1,nPageTop+nRow,24,xlCenter);             //设置垂直对齐方式
      SetRangeValue(nPageTop+nRow,1,nPageTop+nRow,24,pm_Title);                         //设置指定区域的值
      //处理第2行数据
      nRow := 2;
      SetRowHeight(nPageTop+nRow,23.25);
      //设定合并单元格
      MergeCells(nPageTop+nRow,1,nPageTop+nRow,2);
      SetRangeFontStyle(nPageTop+nRow,1,nPageTop+nRow,2,'常规','宋体',AFontColor,11);
      SetRangeHorizontalAlignment(nPageTop+nRow,1,nPageTop+nRow,2,xlCenter);
      SetRangeVerticalAlignment(nPageTop+nRow,1,nPageTop+nRow,2,xlCenter);
      SetRangeValue(nPageTop+nRow,1,nPageTop+nRow,2,'线路名称:');
      //
      MergeCells(nPageTop+nRow,3,nPageTop+nRow,6);
      SetRangeFontStyle(nPageTop+nRow,3,nPageTop+nRow,6,'常规','宋体',AFontColor,11);
      SetRangeHorizontalAlignment(nPageTop+nRow,3,nPageTop+nRow,6,xlLeft);
      SetRangeVerticalAlignment(nPageTop+nRow,3,nPageTop+nRow,6,xlCenter);
      SetRangeValue(nPageTop+nRow,3,nPageTop+nRow,6,AXLMC);      //线路名称

      MergeCells(nPageTop+nRow,7,nPageTop+nRow,8);
      SetRangeFontStyle(nPageTop+nRow,7,nPageTop+nRow,8,'常规','宋体',AFontColor,11);
      SetRangeHorizontalAlignment(nPageTop+nRow,7,nPageTop+nRow,8,xlRight);
      SetRangeVerticalAlignment(nPageTop+nRow,7,nPageTop+nRow,8,xlCenter);
      SetRangeValue(nPageTop+nRow,7,nPageTop+nRow,8,'');      //'变电站名称:';
      //
      MergeCells(nPageTop+nRow,9,nPageTop+nRow,14);
      SetRangeFontStyle(nPageTop+nRow,9,nPageTop+nRow,14,'常规','宋体',AFontColor,11);
      SetRangeHorizontalAlignment(nPageTop+nRow,9,nPageTop+nRow,14,xlLeft);
      SetRangeVerticalAlignment(nPageTop+nRow,9,nPageTop+nRow,14,xlCenter);
      SetRangeValue(nPageTop+nRow,9,nPageTop+nRow,14,ABDZMC);      //赋变电站名称

      MergeCells(nPageTop+nRow,21,nPageTop+nRow,23);
      SetRangeFontStyle(nPageTop+nRow,21,nPageTop+nRow,23,'常规','宋体',AFontColor,11);
      SetRangeHorizontalAlignment(nPageTop+nRow,21,nPageTop+nRow,23,xlCenter);
      SetRangeVerticalAlignment(nPageTop+nRow,21,nPageTop+nRow,23,xlCenter);
      SetRangeValue(nPageTop+nRow,21,nPageTop+nRow,23,'');

      //处理第3行数据
      nRow := 3;
      SetRowHeight(nPageTop+nRow,100);
      MergeCells(nPageTop+nRow,1,nPageTop+nRow,2);
      SetRangeOutBorderStyle(nPageTop+nRow,1,nPageTop+nRow,2,1,1,1);
      SetRangeFontStyle(nPageTop+nRow,1,nPageTop+nRow,2,'常规','宋体',AFontColor,11);
      SetRangeHorizontalAlignment(nPageTop+nRow,1,nPageTop+nRow,2,xlCenter);
      SetRangeVerticalAlignment(nPageTop+nRow,1,nPageTop+nRow,2,xlCenter);
      SetRangeValue(nPageTop+nRow,1,nPageTop+nRow,2,'断  面  图');

      MergeCells(nPageTop+nRow,3,nPageTop+nRow,24);
      SetRangeOutBorderStyle(nPageTop+nRow,3,nPageTop+nRow,24,1,1,1);
      SetRangeFontStyle(nPageTop+nRow,3,nPageTop+nRow,24,'常规','宋体',AFontColor,11);

      nRow := 4;
      SetRowHeight(nPageTop+nRow,69);

      MergeCells(nPageTop+nRow,1,nPageTop+nRow,2);
      SetRangeOutBorderStyle(nPageTop+nRow,1,nPageTop+nRow,2,1,1,1);
      SetRangeFontStyle(nPageTop+nRow,1,nPageTop+nRow,2,'常规','宋体',AFontColor,11);
      SetRangeHorizontalAlignment(nPageTop+nRow,1,nPageTop+nRow,2,xlCenter);
      SetRangeVerticalAlignment(nPageTop+nRow,1,nPageTop+nRow,2,xlCenter);
      SetRangeValue(nPageTop+nRow,1,nPageTop+nRow,2,'平  面  图');

      MergeCells(nPageTop+nRow,3,nPageTop+nRow,24);
      SetRangeOutBorderStyle(nPageTop+nRow,3,nPageTop+nRow,24,1,1,1);
      SetRangeFontStyle(nPageTop+nRow,3,nPageTop+nRow,24,'常规','宋体',AFontColor,11);
      //InitShape(Sheet, APage);      //初始化图
      //5
      nRow := nRow+1;
      sColName := '杆 号';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);

      //6
      nRow := nRow+1;
      sColName := '电杆种类及杆型';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);
      //7
      nRow := nRow+1;
      sColName := '杆高(米)';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);
      //8
      nRow := nRow+1;
      sColName := '埋深(米)';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);

      nRow := nRow+1;
      sColName := '导线型号';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);

      nRow := nRow+1;
      sColName := '档距(米)';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);
      nRow := nRow+1;
      sColName := '累计长度(米)';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);
      nRow := nRow+1;
      sColName := '线路转角';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);
      nRow := nRow+1;
      sColName := '交叉跨越';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);
      nRow := nRow+1;
      sColName := '垂直距离';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);
      nRow := nRow+1;
      sColName := '横担规格';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);
      nRow := nRow+1;
      sColName := '拉线位置';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);
      nRow := nRow+1;
      sColName := '拉线型号/根数';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);
      nRow := nRow+1;
      sColName := '绝缘子型号/数量';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);
      nRow := nRow+1;
      sColName := '变台型式';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);
      nRow := nRow+1;
      sColName := '配变容量';
      FormatCells(APage, nColNum, nRow, sColName, AValueList);
      nRow := nRow+1;
      SetRowHeight(nPageTop+nRow,15);

      if V_PageOffset = 0 then
      begin
        //计算页间距
        V_PageOffset := 0;
        for i := 1 to pm_PageRows do
        begin
          V_PageOffset := V_PageOffset + Sheet.Rows[i].RowHeight;
        end;
        V_PageOffset := V_PageOffset - 1;    //经验值
      end;
    end;

    {
    功能描述:获取指定范围的值
    输入参数:ABegRowNum: 指定范围的起始行号
              ABegColNum:起始列号
              AEndRowNum:终止行号
              AEndColNum: 终止列号
    输出参数:返回指定范围的值
    创建时间:2006-04-13
    创建人:  赵占轻
    }
    function  TExcel.GetRangeValue(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer):String;                    //获取指定范围的值
    var
      vBegCell,vEndCell:Variant;
      vRange:Variant;
    begin
      try
        vBegCell:=Sheet.cells[ABegRowNum,ABegColNum];
        vEndCell:=Sheet.cells[AEndRowNum,AEndColNum];
        vRange:=Sheet.Range[vBegCell,vEndCell];
        Result:=vRange.value;
      except
      end;
    end;

    {
    功能描述:设置指定范围的值
    输入参数:ABegRowNum  指定范围的起始行号
              ABegColNum  指定范围的起始列号
              AEndRowNum  指定范围的终止行号
              AEndColNum  指定范围的终止列号
              AValue      待写入指定范围的值
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-13
    创建人:  赵占轻
    }
    function  TExcel.SetRangeValue(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer;AValue:string):Boolean;     //设置指定范围的值
    var
      vBegCell,vEndCell:Variant;
      vRange:Variant;
    begin
      try
        vBegCell:=Sheet.cells[ABegRowNum,ABegColNum];
        vEndCell:=Sheet.cells[AEndRowNum,AEndColNum];
        vRange:=Sheet.Range[vBegCell,vEndCell];
        vRange.Value:=AValue;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置指定区域格式为自动换行
    输入参数:ABegRowNum   指定的范围的起始行号
              ABegColNum   指定的范围的起始列号
              AEndRowNum   指定的范围的终止行号
              AEndColNum   指定的范围的终止列号
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.SetRangeAutoWrap(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer):Boolean;  //设置指定区域格式为自动换行
    var
      vBegCell,vEndCell:Variant;
      vRange:Variant;
    begin
      try
        vBegCell:=Sheet.Cells[ABegRowNum,ABegColNum];
        vEndCell:=Sheet.Cells[AEndRowNum,AEndColNum];
        vRange:=Sheet.Range[vBegCell,vEndCell];
        vRange.WrapText := 1;                        //自动换行
        vRange.ShrinkToFit := False;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:取消指定区域的自动换行
    输入参数:ABegRowNum  指定的范围的起始行号
              ABegColNum  指定的范围的起始列号
              AEndRowNum  指定的范围的终止行号
              AEndColNum  指定的范围的终止列号
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.CancelRangeAutoWrap(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer):Boolean;
    var
      vBegCell,vEndCell:Variant;
      vRange:Variant;
    begin
      try
        vBegCell:=Sheet.Cells[ABegRowNum,ABegColNum];
        vEndCell:=Sheet.Cells[AEndRowNum,AEndColNum];
        vRange:=Sheet.Range[vBegCell,vEndCell];
        vRange.WrapText := 0;                        //自动换行
        vRange.ShrinkToFit := True;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:    获取指定页,指定cell的断面杆的中心坐标
    输入参数:    APage       当前页号
                  ACellIndex  当前单元格列号
    输出参数:    无
    输入输出参数:AX  用于返回断面杆的中心X坐标
                  AY  用于返回断面杆的中心Y坐标
    创建时间:    2006-04-18
    创建人:      赵占轻
    }
    procedure TExcel.GetCellDMGanCoord(APage, ACellIndex: Integer;var AX, AY: Double);
    begin
      AX := pm_GanFirstLeft+((ACellIndex-1)*pm_GanOffset) + pm_GanD/2;
      AY := (APage-1)*V_PageOffset+dm_GanTop;
    end;

    {
    功能描述:    创建断面图
    输入参数:     AX1           杆塔底端X坐标
                  AY1           杆塔底端Y坐标
                  AGanGao       实际杆高
                  AIsTJPole     是否T接杆
                  AIsFirstPole  是否第一颗杆
                  AIsCable      是否下电缆杆
    输出参数:    无
    输入输出参数:AOldY2:返回杆塔的顶点Y坐标
    创建时间:     2006-04-18
    创建人:      赵占轻

    }
    procedure TExcel.CreateDMT(AX1, AY1, AGanGao: Double;AIsTJPole, AIsFirstPole, AIsCable: Boolean;var AOldY2: Double);
    //创建断面图
    var
      AX2, AY2: Double;
      AShape: Variant;
      freBuilder: Variant;
    begin
      AGanGao := GetPoleHight(AGanGao);  //计算图上杆高
      AX2 := AX1;// + pm_GanOffset;
      AY2 := AY1 - dm_HaiBa - AGanGao;
      //断面图杆
      Sheet.Shapes.Addline(AX1, AY1 ,AX2, AY2);

      if not AIsFirstPole then
      begin
        if AIsCable then
        begin
          //断面图电缆
          AShape := Sheet.Shapes.AddLine(AX2, AY2, AX2-3, AY2);
          AShape.Line.DashStyle := 4;
          AShape := Sheet.Shapes.AddLine(AX2-3, AY2, AX2-3, AY2+AGanGao-3);
          AShape.Line.DashStyle := 4;
          AShape := Sheet.Shapes.AddLine(AX2-3, AY2+AGanGao-3, AX2-pm_GanOffset+3, AY2+AGanGao-3);
          AShape.Line.DashStyle := 4;
          AShape := Sheet.Shapes.AddLine(AX2-pm_GanOffset+3, AY2+AGanGao-3, AX2-pm_GanOffset+3, AOldY2);
          AShape.Line.DashStyle := 4;
          AShape := Sheet.Shapes.AddLine(AX2-pm_GanOffset+3, AOldY2, AX2-pm_GanOffset, AOldY2);
          AShape.Line.DashStyle := 4;
        end
        else begin
          //断面图导线
          freBuilder := Sheet.Shapes.BuildFreeform(msoEditingAuto, AX2, AY2);
          if AOldY2 - AY2 > dm_HuChui then
          begin
            freBuilder.AddNodes(msoSegmentCurve, msoEditingAuto, AX2-pm_GanOffset/2, AY2+(AOldY2-AY2)/2+dm_HuChui);
          end
          else begin
            freBuilder.AddNodes(msoSegmentCurve, msoEditingAuto, AX2-pm_GanOffset/2, AY2+dm_HuChui);
          end;
          freBuilder.AddNodes(msoSegmentCurve, msoEditingAuto, AX2-pm_GanOffset, AOldY2);
          freBuilder.ConvertToShape;
        end;
      end
      else begin
        if not AIsTJPole then
        begin
          //如果不是T接杆
          freBuilder := Sheet.Shapes.BuildFreeform(msoEditingAuto, AX2, AY2);
          freBuilder.AddNodes(msoSegmentCurve, msoEditingAuto, AX2-pm_GanOffset/4, AY2+(dm_HuChui*2/3));
          freBuilder.AddNodes(msoSegmentCurve, msoEditingAuto, AX2-pm_GanOffset/2, AY2+dm_HuChui);
          freBuilder.ConvertToShape;
        end;
      end;
      AOldY2 := AY2;
    end;

    {
    功能描述:    获取指定页,指定cell的杆的中心坐标
    输入参数:    APage       当前页号
                  ACellIndex  单元格列号
    输出参数:    无
    输入输出参数:计算结构存入AX,AY中
    创建时间:    2006-04-18
    创建人:      李志强
    }
    procedure TExcel.GetCellGanCoord(APage, ACellIndex: Integer;var AX, AY: Double);
    begin
      AX := pm_GanFirstLeft+((ACellIndex-1)*pm_GanOffset) + pm_GanD/2;
      AY := (APage-1)*V_PageOffset+pm_GanTop + pm_GanD/2;
    end;

    {
    功能描述:画分支  创建转角箭头线
    输入参数:AX             箭头线起点X坐标
              AY             箭头线起点Y坐标
              AYOffSet       文本框偏移量
              AAngle         箭头线转角
              AXLMC          分支名称
    输出参数:无
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    procedure TExcel.CreateFZLine(AX, AY,AYOffSet,AAngle: Double;AXLMC: String);
    var
      vShape: Variant;
      dX2, dY2: Double;
      vSelection:Variant;
    begin
      //角度向右为负  图形显示向下
      dX2 := AX + pm_Distance * Sin((90-AAngle)*Pi/180);
      dY2 := AY - pm_Distance * Cos((90-AAngle)*Pi/180);
      vShape := Sheet.Shapes.AddLine(AX, AY, dX2, dY2);
      //格式化箭头线
      FormatArrowLineEndHead(vShape,msoArrowheadTriangle,msoArrowheadLengthMedium,msoArrowheadWidthMedium);
      FormatArrowLine(vShape,1.5,msoLineSingle,msoLineSolid);
      //插入文本框
      if AAngle < 0 then
      begin
        vSelection:=Sheet.Shapes.AddTextbox(msoTextOrientationHorizontal, AX-pm_GanOffset/2-5, AY+25+AYOffSet, 70, 11).Select;
      end
      else begin
        vSelection:=Sheet.Shapes.AddTextbox(msoTextOrientationHorizontal, AX-pm_GanOffset/2-5, AY-26+AYOffSet, 70, 11).Select;
      end;
      //格式化文本框
      SetTextBoxFillStyle(vSelection,msoFalse,0);         //设置文本框填充样式
      SetTextBoxLineStyle(vSelection,msoFalse,0);         //设置文本框边线样式
      SetTextBoxFontStyle(vSelection,'宋体','常规',9,0);  //设置文本框字体样式
      SetTextBoxText(vSelection,AXLMC);                   //设置文本框内容
      SetTextBoxAlignment(vSelection,xlCenter,xlCenter);  //设置文本框对齐方式
    end;

    {
    功能描述:创建转角箭头线
    输入参数:AX      转角箭头线的起始X坐标
              AY      转角箭头线的起始Y坐标
              AAngle  转角箭头线的角度
    输出参数:无
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    procedure TExcel.CreateArrowheadLine(AX, AY, AAngle: Double);
    var
      vShape: Variant;
      dX2, dY2: Double;
    begin
      //角度向右为负  图形显示向下
      dX2 := AX + pm_Distance * Sin((90-AAngle)*Pi/180);      //计算转角箭头线的终点X坐标
      dY2 := AY - pm_Distance * Cos((90-AAngle)*Pi/180);      //计算转角箭头线的终点Y坐标
      vShape := Sheet.Shapes.AddLine(AX, AY, dX2, dY2);       //绘制转角箭头线
      //下面设置箭头线的样式
      Self.FormatArrowLineEndHead(vShape,msoArrowheadTriangle,msoArrowheadLengthMedium,msoArrowheadWidthMedium);
    end;

    {
    功能描述:双精度的度转换为度分秒
    输入参数:双精度的角度
    输出参数:返回度分秒字符串
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.DoubleToFenMiao(Jiao:Double):string;
    var
      TmpD:double;
      TmpI:integer;
      Str:string;
    begin
      TmpI:=Trunc(Jiao);
      Str:=IntToStr(TmpI);
      TmpD:=Jiao-TmpI;
      TmpD:=TmpD*60;
      TmpI:=Trunc(TmpD);
      //Str:=Str+'度'+IntToStr(TmpI);
      Str:=Str+'°'+IntToStr(TmpI);
      TmpD:=TmpD-TmpI;
      TmpD:=TmpD*60;
      TmpI:=Trunc(TmpD);
      //Str:=Str+'分'+IntToStr(TmpI)+'秒';
      Str:=Str+'′'+IntToStr(TmpI)+'″';
      result:=Str;
    end;

    {
    功能描述:绘制变压器文本
    输入参数:AX     文本X坐标
              AY     文本Y坐标
              AText  文本内容
    输出参数:无
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    procedure TExcel.DrawBYQText(AX, AY : Double;AText: String);
    var
      vSelection:Variant;
    begin
      vSelection:=InsertTextBox(AX-pm_GanOffset/2+1,AY+7,58,33,msoTextOrientationHorizontal);  //插入文本框
      SetTextBoxAlignment(vSelection,xlCenter,xlCenter);          //设置文本框对齐方式
      SetTextBoxFillStyle(vSelection,msoFalse,0);                 //设置文本框填充样式
      SetTextBoxLineStyle(vSelection,msoFalse,0);                 //设置文本框边线样式
      SetTextBoxFontStyle(vSelection,'宋体','常规',9,0,);         //设置文本框的字体样式
      Self.SetTextBoxText(vSelection,AText);                      //设置文本框内容
    end;

    {
    功能描述:绘制变压器
    输入参数:AX  初始X坐标
              AY:初始Y坐标
    输入参数:无
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    procedure TExcel.DrawBYQ(AX, AY : Double);
    var
      AX2, AY2: Double;
      AShape: Variant;
    begin
      AY2 := AY + pm_BYQY;
      AX2 := AX - pm_GanD;
      AShape := Sheet.Shapes.AddShape(msoShapeOval, AX2, AY2, pm_BYQD, pm_BYQD);  //绘制左圈
      AShape.Fill.Visible := False;
      AX2 := AX-pm_GanD/3;
      AShape := Sheet.Shapes.AddShape(msoShapeOval, AX2, AY2, pm_BYQD, pm_BYQD);  //绘制右圈
      AShape.Fill.Visible := False;
    end;

    {
    功能描述:设置指定行的行高
    输入参数:ARowNum:     指定行的行号;
              ARowHeight:  目标行高度值
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.SetRowHeight(ARowNum:Integer;ARowHeight:Double):Boolean;
    begin
      try
        Sheet.Rows[ARowNum].RowHeight := ARowHeight;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:以15米杆高为标准计算d当前杆塔图形高度
    输入参数:AHight:杆塔高度
    输出参数:杆塔高度
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.GetPoleHight(AHight: Double): Double;
    begin
      //已15米杆为标准
      Result := AHight*(80/15);
    end;


    {
    功能描述:向指定工作表中插入图片
    输入参数:ABeginRow   图片左上脚所处的单元格行号
              ABeginCol   图片左上脚所处的单元格列号
              APicFile    要插入的图片的全名
    输出参数:插入成功返回真否则返回假
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function  TExcel.InsertPicIntoSheet(ABeginRow,ABeginCol:Integer;APicFile:String):Boolean;
    var
      vBeginCell:Variant;
    begin
      try
        vBeginCell:=Sheet.Cells[ABeginRow,ABeginCol];
        vBeginCell.Select;
        Sheet.Pictures.Insert(APicFile);
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置指定范围的背景图案
    输入参数: ABegRowNum    指定的范围的起始行号
              ABegColNum    指定的范围的起始列号
              AEndRowNum    指定的范围的终止行号
              AEndColNum    指定的范围的终止列号
              APattern      图案样式
              APatternColor 图案颜色
              ABackColor    背景颜色
              
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-17
    创建人:   赵占轻
    }
    function TExcel.SetRangeBackGround(ABegRowNum,ABegColNum,AEndRowNum,AEndColNum:Integer;
             APattern:Integer=xlSolid;APatternColor:Integer=xlNone;ABackColor:Integer=xlNone):Boolean;
    var
      vBegCell,vEndCell:Variant;
      vRange:Variant;
    begin
      try
        vBegCell:=Sheet.Cells[ABegRowNum,ABegColNum];
        vEndCell:=Sheet.Cells[AEndRowNum,AEndColNum];
        vRange:=Sheet.Range[vBegCell,vEndCell];
        vRange.Interior.ColorIndex:=ABackColor;
        vRange.Interior.Pattern:=APattern;
        vRange.Interior.PatternColorIndex:=APatternColor;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:在指定位置插入文本框
    输入参数:AX       文本框左上角X坐标
              AY       文本框左上角Y坐标
              AWidth   文本框宽
              AHeight  文本框高
              AAlign   文本框中文本方向
                       (xlHorizontal 文字字头朝上 横向排列
                        xlVertical   文字字头朝上 竖向排列
                        xlUpward     文字字头朝右 横向排列
                        xlDownward   文字字头朝左 横向排列
                       )
    输出参数:执行成功返回插入的文本框
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.InsertTextBox(AX,AY,AWidth,AHeight:Double;AOrient:Integer=msoTextOrientationHorizontalRotatedFarEast):Variant;
    begin
      try
        Sheet.Shapes.AddTextbox(AOrient,AX, AY,AWidth,AHeight).Select;
        Result:=MyExcel.selection;//加入文本框
      except
      end;
    end;

    {
    功能描述:设置文本框填充样式
    输入参数:ATextBox       指定的文本框
              AVisible       文本框是否显示填充样式
              ATransparency  透明程度
                         0: 不透明
                         0.5 半透明
                         1   透明

    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.SetTextBoxFillStyle(ATextBox:Variant;AVisible:Integer;ATransparency:Double=0):Boolean;
    begin
      try
        ATextBox.ShapeRange.Fill.Visible := AVisible;
        ATextBox.ShapeRange.Fill.Transparency := ATransparency;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置文本框边框样式
    输入参数:ATextBox:      指定文本框;
              AVisible:     边框是否可见;
              ATransparency:透明程度
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.SetTextBoxLineStyle(ATextBox:Variant;AVisible:Integer;ATransparency:Double=0):Boolean;
    begin
      try
        ATextBox.ShapeRange.Line.Transparency := ATransparency;
        ATextBox.ShapeRange.Line.Visible := AVisible;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置文本框中文字内容
    输入参数:ATextBox: 指定文本框
              AText:   内容字符串
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.SetTextBoxText(ATextBox:Variant;AText:string):Boolean;
    begin
      try
        ATextBox.Characters.Text := AText;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置文本框中字体样式
    输入参数:ATextBox:     指定文本框;
              AFontName:   字体名称;
              AFontStyle:   字体样式;
              AFontSize:   字体大小
              AFontColor:   字体颜色
              
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.SetTextBoxFontStyle(ATextBox:Variant;AFontName,AFontStyle:String;AFontSize:Integer=12;AFontColor:Integer=0):Boolean;
    begin
      try
        //设置文本框样式
        ATextBox.Font.Name := '宋体';
        ATextBox.Font.Size := AFontSize;
        ATextBox.Font.ColorIndex:=AFontColor;                 //设置字体颜色
        ATextBox.Font.FontStyle:=AFontStyle;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置文本框水平和垂直对齐方式
    输入参数:ATextBox:    指定文本框
              HAlign:     水平对齐方式;(xlCenter 居中 ;xlLeft 靠左;xlRight 靠右;xlJustify 两端对齐)
              VAlign:     垂直对齐方式  (xlCenter 居中 ;xlTop 靠左;xlBottom 靠右;xlJustify 两端对齐)
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.SetTextBoxAlignment(ATextBox:Variant;HAlign:Integer=xlLeft;VAlign:Integer=xlBottom):Boolean;
    begin
      try
        ATextBox.HorizontalAlignment := HAlign;
        ATextBox.VerticalAlignment := VAlign;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:格式化箭头线的末端样式
    输入参数:ALine        待格式化的箭头线
              AheadStyle   末端样式
              AheadLength  末端长
              AheadWidth   末端宽
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.FormatArrowLineEndHead(ALine:Variant;AheadStyle:Integer=msoArrowheadTriangle;
                 AheadLength:Integer=msoArrowheadLengthMedium;AheadWidth:Integer=msoArrowheadWidthMedium):Boolean;
    begin
      try
        ALine.Line.EndArrowheadLength := AheadLength;
        ALine.Line.EndArrowheadWidth := AheadWidth;
        ALine.Line.EndArrowheadStyle := AheadStyle;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:格式化箭头线的首端样式
    输入参数:ALine        待格式化的箭头线
              AheadStyle   首端样式
              AheadLength  首端长
              AheadWidth   首端宽
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.FormatArrowLineBeginHead(ALine:Variant;AheadStyle:Integer=msoArrowheadTriangle;
                 AheadLength:Integer=msoArrowheadLengthMedium;AheadWidth:Integer=msoArrowheadWidthMedium):Boolean;
    begin
      try
        ALine.Line.BeginArrowheadLength := AheadLength;
        ALine.Line.BeginArrowheadWidth := AheadWidth;
        ALine.Line.BeginArrowheadStyle := AheadStyle;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:格式化箭头线的线样式
    输入参数:ALine        待格式化的箭头线
              AWidth       线宽
              AStyle       线样式
              ADashStyle   虚线样式
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-17
    创建人:  赵占轻
    }
    function TExcel.FormatArrowLine(ALine:Variant;AWidth:Double=1.5;AStyle:Integer=msoLineSingle;ADashStyle:Integer=msoLineSolid):Boolean;
    begin
      try
        ALine.Line.Weight := AWidth;
        ALine.Line.DashStyle := ADashStyle;
        ALine.Line.Style := AStyle;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置当前窗口网格的显示与否
    输入参数:IsVisible:控制网格显示的参数
                  (True:显示网格;False:隐藏网格)
    输出参数:执行成功返回真否则返回假
    创建时间:2006-05-07
    创建人:  赵占轻
    }
    function TExcel.SetActiveWindowGridVisible(IsVisible:Boolean=True):Boolean;        //设置当前窗口网格的显示与否
    begin
      Result:=False;
      try
        MyExcel.Application.ActiveWindow.DisplayGridlines:=IsVisible;
      except
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置指定行的字体样式
    输入参数:ARowNum:  待设置的行的行号
              AFontStyle:目标字体样式(如粗体);
              AFontName: 目标字体名称;
              AFontColor 目标字体颜色
              AFontSize: 目标字体大小
    输出参数:执行成功返回真;否则返回假
    创建时间:2006-05-08
    创建人:  赵占轻
    }
    function  TExcel.SetRowFontStyle(ARowNum:Integer;AFontStyle:string='常规';AFontName:string='宋体';
                                    AFontColor:Integer=0;AFontSize:Integer=12):Boolean;
    var
      vRange:Variant;
    begin
      try
        vRange:=Sheet.Rows[ARowNum];
        vRange.Font.ColorIndex:=AFontColor;                 //设置字体颜色
        vRange.Font.Name:=AFontName;                        //设置字体名称
        vRange.Font.Size:=AFontSize;                        //设置字体大小
        vRange.Font.FontStyle:=AFontStyle;                  //设置字体样式
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置指定列的字体样式
    输入参数:AColNum:     待设置的列的列号
              AFontStyle:   目标字体样式(如粗体);
              AFontName:    目标字体名称;
              AFontColor:   目标字体颜色
              AFontSize:    目标字体大小
    输出参数:执行成功返回真;否则返回假
    创建时间:2006-05-08
    创建人:  赵占轻
    }
    function  TExcel.SetColumnFontStyle(AColNum:Integer;AFontStyle:string='常规';AFontName:string='宋体';
                                     AFontColor:Integer=0;AFontSize:Integer=12):Boolean;        //设置指定列的字体样式
    var
      vRange:Variant;
    begin
      try
        vRange:=Sheet.Columns[AColNum];
        vRange.Font.ColorIndex:=AFontColor;                 //设置字体颜色
        vRange.Font.Name:=AFontName;                        //设置字体名称
        vRange.Font.Size:=AFontSize;                        //设置字体大小
        vRange.Font.FontStyle:=AFontStyle;                  //设置字体样式
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置指定行的外边框样式
    输入参数:ARowNum     待设置行的行号
              AWeight     边线粗度
              ALineColor  边线颜色
              ALineStyle  边线样式
    输出参数:执行成功返回真否则返回假
    创建时间:2006-05-08
    创建人:  赵占轻
    }
    function TExcel.SetRowOutBorderStyle(ARowNum:Integer;AWeight:Integer=2;
                                     ALineColor:Integer=0;ALineStyle:Integer=xlContinuous):Boolean;        //设置指定行的外边框样式
    var
      vRange:Variant;
    begin
      vRange:=Sheet.Rows[ARowNum];
      try
        //设置左边框
        vRange.Borders.Item[xlEdgeLeft].LineStyle :=ALineStyle;
        vRange.Borders.Item[xlEdgeLeft].Weight := AWeight;
        vRange.Borders.Item[xlEdgeLeft].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      try
        //设置顶边框
        vRange.Borders.Item[xlEdgeTop].LineStyle := ALineStyle;
        vRange.Borders.Item[xlEdgeTop].Weight := AWeight;
        vRange.Borders.Item[xlEdgeTop].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      try
        //设置底边框
        vRange.Borders.Item[xlEdgeBottom].LineStyle := ALineStyle;
        vRange.Borders.Item[xlEdgeBottom].Weight := AWeight;
        vRange.Borders.Item[xlEdgeBottom].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      try
        //设置右边框
        vRange.Borders.Item[xlEdgeRight].LineStyle := ALineStyle;
        vRange.Borders.Item[xlEdgeRight].Weight := AWeight;
        vRange.Borders.Item[xlEdgeRight].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置指定列的外边框样式
    输入参数:AColNum      待设置列的列号
              AWeight      边线粗度
              ALineColor   边线颜色
              ALineStyle   边线样式
    输出参数:执行成功返回真否则返回假
    创建时间:2006-05-08
    创建人:  赵占轻
    }
    function TExcel.SetColumnOutBorderStyle(AColNum:Integer;AWeight:Integer=2;ALineColor:Integer=0;        //设置指定列的外边框样式
                                    ALineStyle:Integer=xlContinuous):Boolean;
    var
      vRange:Variant;
    begin
      vRange:=Sheet.Columns[AColNum];
      try
        //设置左边框
        vRange.Borders.Item[xlEdgeLeft].LineStyle :=ALineStyle;
        vRange.Borders.Item[xlEdgeLeft].Weight := AWeight;
        vRange.Borders.Item[xlEdgeLeft].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      try
        //设置顶边框
        vRange.Borders.Item[xlEdgeTop].LineStyle := ALineStyle;
        vRange.Borders.Item[xlEdgeTop].Weight := AWeight;
        vRange.Borders.Item[xlEdgeTop].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      try
        //设置底边框
        vRange.Borders.Item[xlEdgeBottom].LineStyle := ALineStyle;
        vRange.Borders.Item[xlEdgeBottom].Weight := AWeight;
        vRange.Borders.Item[xlEdgeBottom].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      try
        //设置右边框
        vRange.Borders.Item[xlEdgeRight].LineStyle := ALineStyle;
        vRange.Borders.Item[xlEdgeRight].Weight := AWeight;
        vRange.Borders.Item[xlEdgeRight].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置指定行的分隔线样式
    输入参数:ARowNum    待设置的行号
              AWeight    分割线粗度
              ALineColor 分割线颜色
              ALineStyle 分割线样式
    输出参数:执行成功返回真否则返回假
    创建时间:2006-05-08
    创建人:  赵占轻
    }
    function TExcel.SetRowInnerLineStyle(ARowNum:Integer;AWeight:Integer=2;ALineColor:Integer=0;        //设置指定行的分隔线样式
                                    ALineStyle:Integer=xlContinuous):Boolean;
    var
      vRange:Variant;
    begin
      vRange:=Sheet.Rows[ARowNum];
      try
        //设置垂直线样式
        vRange.Borders.Item[xlInsideVertical].LineStyle :=ALineStyle;
        vRange.Borders.Item[xlInsideVertical].Weight := AWeight;
        vRange.Borders.Item[xlInsideVertical].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      try
        //设置水平线样式
        vRange.Borders.Item[xlInsideHorizontal].LineStyle := ALineStyle;
        vRange.Borders.Item[xlInsideHorizontal].Weight := AWeight;
        vRange.Borders.Item[xlInsideHorizontal].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;
    {
    功能描述:设置指定列的分隔线样式
    输入参数:AColNum     待设置的列号
              AWeight     分割线粗度
              ALineColor  分割线颜色
              ALineStyle  分割线样式
    输出参数:执行成功返回真否则返回假
    创建时间:2006-05-08
    创建人:  赵占轻

    }
    function TExcel.SetColumnInnerLineStyle(AColNum:Integer;AWeight:Integer=2;ALineColor:Integer=0;        //设置指定列的分隔线样式
                                    ALineStyle:Integer=1):Boolean;
    var
      vRange:Variant;
    begin
      vRange:=Sheet.Columns[AColNum];
      try
        //设置垂直线样式
        vRange.Borders.Item[xlInsideVertical].LineStyle :=ALineStyle;
        vRange.Borders.Item[xlInsideVertical].Weight := AWeight;
        vRange.Borders.Item[xlInsideVertical].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      try
        //设置水平线样式
        vRange.Borders.Item[xlInsideHorizontal].LineStyle := ALineStyle;
        vRange.Borders.Item[xlInsideHorizontal].Weight := AWeight;
        vRange.Borders.Item[xlInsideHorizontal].ColorIndex := ALineColor;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置指定行的水平对其方式
    输入参数:ARowNum   待设置的列号
              AAlign    对其方式  常用值:
                       xlCenter 居中
                       xlLeft 靠左
                       xlRight 靠右
                       xlJustify 两端对齐
                      
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-13
    创建人:  赵占轻
    }

    function  TExcel.SetRowHorizontalAlignment(ARowNum:Integer;AAlign:Integer=xlLeft):Boolean;  
    var
      vRange:Variant;
    begin
      try
        vRange:=Sheet.Rows[ARowNum];
        vRange.HorizontalAlignment:= AAlign;   
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置指定行的垂直对其方式
    输入参数:ARowNum  待设置的行号
              AAlign   对其方式  常用值
                        xlCenter居中
                        xlTop 靠左
                        xlBottom 靠右
                        xlJustify 两端对齐

    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-13
    创建人:  赵占轻
    }

    function  TExcel.SetRowVerticalAlignment(ARowNum:Integer;AAlign:Integer=xlBottom):Boolean;           //设置指定行的垂直平对其方式
    var
      vRange:Variant;
    begin
      try
        vRange:=Sheet.Rows[ARowNum];
        vRange.VerticalAlignment:= AAlign;   
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置指定列的水平对其方式
    输入参数:AColNum  待设置的列号
              AAlign   对其方式
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-13
    创建人:  赵占轻
    }

    function  TExcel.SetColumnHorizontalAlignment(AColNum:Integer;AAlign:Integer=xlLeft):Boolean;  //设置指定列的水平对其方式
    var
      vRange:Variant;
    begin
      try
        vRange:=Sheet.Columns[AColNum];
        vRange.HorizontalAlignment:= AAlign;  
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:设置指定列的垂直对其方式
    输入参数:AColNum: 待设置的列号;AAlign:对其方式
    输出参数:执行成功返回真否则返回假
    创建时间:2006-04-13
    创建人:  赵占轻
    }
    function  TExcel.SetColumnVerticalAlignment(AColNum:Integer;AAlign:Integer=xlBottom):Boolean;
    var
      vRange:Variant;
    begin
      try
        vRange:=Sheet.Columns[AColNum];
        vRange.VerticalAlignment:= AAlign;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;

    {
    功能描述:Excel数据保存到文件
    输入参数:AFileName:待保存的文件全名
    输出参数:保存成功返回真否则返回假
    创建时间:2006-05-30
    创建人:  赵占轻
    }
    function  TExcel.SaveToFile(AFileName:string):Boolean;              //Excel数据保存到文件
    begin
      try
        if FileExists(AFileName) then
        begin
          if DeleteFile(AFileName) then
          begin
            MyExcel.ActiveWorkbook.saveAs(AFileName);
          end else
          begin
            Result:=False;
            Exit;
          end;
        end else
        begin
          MyExcel.ActiveWorkbook.saveAs(AFileName);
        end;
      except
        Result:=False;
        Exit;
      end;
      Result:=True;
    end;


    end.//This Unit is over;
  • 相关阅读:
    Mvc3绑定下拉菜单
    M vc3+ExtJs 数据格式转换(泛型集合转换为Json类型)
    python代码小实践之dorm_lab_changeIP
    2013网易互联网暑假实习笔试&面试
    python代码小实践之split_csv
    python代码小实践之data_structure_and_algorithm
    位运算
    weibo_json
    unsinged and (signed)
    01背包模板 开心的小明
  • 原文地址:https://www.cnblogs.com/weixing/p/2101277.html
Copyright © 2011-2022 走看看