赛迪网 > IT技术 编程语言 > 文章
  IT资讯搜索
 
IT产品搜索
[程序开发][网管世界][网络安全][数据库技术]
[操作系统][嘉宾聊天·在线访谈][活动集锦]
[精彩专题][Symantec专区][订阅IT技术周刊]
[开发论坛][网管论坛][安全论坛][数据库论坛]
[操作系统论坛][Sybase专区][IBM dW技术专区]
[病毒求助][病毒与漏洞播报][文档·源码下载]

多表头的DBGridEH导出到Excel中

发布时间:2006.08.16 03:20     来源:plwww    作者:

多表头的DBGridEH导出到Excel中
把自己的解决法子说一下,虽然解决的不是很完美,缺少单元格合并和字体设置。
我重写了单元DBGridEhImpExp中的函数TDBGridEhExportAsXLS.WriteTitle
希望有高手继续完善这个函数,让之最终导出的Excel格式和Elib一样。
//------------------------------------------------------------------
procedure TDBGridEhExportAsXLS.WriteTitle(ColumnsList: TColumnsEhList);
var
 i, k: Integer;
 FPTitleExpArr: TTitleExpArr;
 ListOfHeadTreeNodeList: TList;
 ColSpan, RowSpan: Integer;
 str1:String;
 L: Word; //writestringcell
begin
 if ColumnsList.Count = 0 then
  Exit;

 if DBGridEh.UseMultiTitle then
 begin
  try
   CreateMultiTitleMatrix(DBGridEh, ColumnsList, FPTitleExpArr, ListOfHeadTreeNodeList);
   //输出除最后一行表头的内容
   for k := ListOfHeadTreeNodeList.Count - 1 downto 1 do
   begin
    for i := 0 to ColumnsList.Count - 1 do
    begin
     if THeadTreeNode(TList(ListOfHeadTreeNodeList.Items[k]).Items[i]) <> nil then
     begin
      CalcSpan(ColumnsList, ListOfHeadTreeNodeList, k, i, ColSpan, RowSpan);
      str1:=THeadTreeNode(TList(ListOfHeadTreeNodeList.Items[k]).Items[i]).Text;
      //=====================================
      L := Length(str1);
      CXlsLabel[1] := 8 + L;
      CXlsLabel[2] := FRow;
      CXlsLabel[3] := FCol;
      CXlsLabel[5] := L;
      StreamWriteWordArray(Stream, CXlsLabel);
      StreamWriteAnsiString(Stream, str1);
      if FCol = ExpCols.Count - 1 then
      begin
       Inc(FRow);
       FCol := 0;
      end
      else
       FCol:=FCol+ColSpan;
      //=====================================
     end;
    end;
   end;
   FRow := ListOfHeadTreeNodeList.Count - 1;
   FCol :=0;
   //输出最后一行表头
   for i := 0 to ColumnsList.Count - 1 do
   begin
    if THeadTreeNode(TList(ListOfHeadTreeNodeList.Items[0]).Items[i]) <> nil then
    begin
     CalcSpan(ColumnsList, ListOfHeadTreeNodeList, 0, i, ColSpan, RowSpan);
     str1:=THeadTreeNode(TList(ListOfHeadTreeNodeList.Items[0]).Items[i]).Text;
     //WriteStringCell(str1);
     //==================================
     L := Length(str1);
     CXlsLabel[1] := 8 + L;
     CXlsLabel[2] := FRow;
     CXlsLabel[3] := FCol;
     CXlsLabel[5] := L*ColSpan;
     StreamWriteWordArray(Stream, CXlsLabel);
     StreamWriteAnsiString(Stream, str1);
     if FCol = ExpCols.Count - 1 then
     begin
      Inc(FRow);
      FCol := 0;
     end
     else
      FCol:=FCol+ColSpan;
     //==================================
    end
    else
    begin
     Inc(FCol);//单云格进一
    end;
   end;
   FRow:=ListOfHeadTreeNodeList.Count;
   FCol:=0;
  finally
   for i := 0 to ListOfHeadTreeNodeList.Count - 1 do
    TList(ListOfHeadTreeNodeList.Items[i]).Free;
   ListOfHeadTreeNodeList.Free;
  end;
 end
 else  //不使用多表头
 begin
  for i := 0 to ColumnsList.Count - 1 do
  begin
   WriteStringCell(ColumnsList[i].Title.Caption);
  end;
 end;
end;
//------------------------------------------------------------------

(出处:www.2ccc.com)


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· 异构数据库之间的导入导出示例 (04-25) · 开发工具大比拼之Visual C++ VS Delphi (01-06)
· Delphi6函数大全(3) (08-09) · 为什么选择Delphi.Net? (01-04)
· Delphi6函数大全(2) (06-26) · Delphi6函数大全(1) (12-06)
· MBA:应用为王 (10-24) · 管理模式:职业经理 (08-26)
· 通过at发送手机短信 (03-28) · 通过http发送手机短信 (03-23)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  信息化 ·热点·专题·访谈·周刊·方案案例
[政务][电信][金融][农业][制造业][中小企业]
[CIO][ERP][协同][IT管理][中间件][电子商务]
[政策][地方][专家][评估][辞典][博客][社区]
· 专题:一路畅通构想曲——让出行不再遭遇堵车
· CIO工作亲历:企业ERP选型不能忽视"选人关"
· 综述:信息化建设给中国监狱带来的各种变化
· 金融业风险管理和法规遵从有五点需考虑的因素
· 保险业CIO关注:该如何建立统一高效的CRM体系
· 调查显示:多数CIO对IT规划仍存在困惑和误解
  博客·论坛 ·曾剑秋·项立刚·Java学习·网管