.NET开发

本类阅读TOP10

·NHibernate快速指南(翻译)
·vs.net 2005中文版下载地址收藏
·【小技巧】一个判断session是否过期的小技巧
·VB/ASP 调用 SQL Server 的存储过程
·?dos下编译.net程序找不到csc.exe文件
·通过Web Services上传和下载文件
·学习笔记(补)《.NET框架程序设计(修订版)》--目录
·VB.NET实现DirectDraw9 (2) 动画
·VB.NET实现DirectDraw9 (1) 托管的DDraw
·建站框架规范书之——文件命名

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
以实例说明如何使用C#从数据库中提取数据,按要求自动生成定制的Excel表格?[原创]

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

最近因为需要学习了一下使用C#操作Excel表格,现在把我使用C#如何定制表格的过程提供给需要的兄弟:
/*从数据库提取数据*/
string strconn="packet size=4096;user id=sa;data source=localhost;persist security info=True;initial catalog=Database;password=sa";
    SqlConnection sqlconn=new SqlConnection(strconn);
    sqlconn.Open();
    SqlDataAdapter sqldataAdapter=new SqlDataAdapter("Select * from [数据表]",sqlconn);
    DataSet myds=new DataSet();
    sqldataAdapter.Fill(myds);
/*在Execl中建立“成果表”的格式表格*/
   Excel.ApplicationClass excel=new Excel.ApplicationClass();
   excel.Application.Workbooks.Add(true);
   excel.Cells[1,1] = "单元名称" ;
   excel.Cells[1,2]="指标及其描述、特征值和权重";
   excel.Cells[1,23]="属性";
   excel.Cells[2,2]="D";
   excel.Cells[2,5]="R";
   excel.Cells[2,8]="A";
   excel.Cells[2,11]="S";
   excel.Cells[2,14]="T";
   excel.Cells[2,17]="I";
   excel.Cells[2,20]="C";
   excel.Cells[2,23]="结果";
   excel.Cells[2,24]="等级";
   excel.Cells[3,2]="描述";
   excel.Cells[3,3]="特征值";
   excel.Cells[3,4]="权重";
   excel.Cells[3,5]="描述";
   excel.Cells[3,6]="特征值";
   excel.Cells[3,7]="权重";
   excel.Cells[3,8]="描述";
   excel.Cells[3,9]="特征值";
   excel.Cells[3,10]="权重";
   excel.Cells[3,11]="描述";
   excel.Cells[3,12]="特征值";
   excel.Cells[3,13]="权重";
   excel.Cells[3,14]="描述";
   excel.Cells[3,15]="特征值";
   excel.Cells[3,16]="权重";
   excel.Cells[3,17]="描述";
   excel.Cells[3,18]="特征值";
   excel.Cells[3,19]="权重";
   excel.Cells[3,20]="描述";
   excel.Cells[3,21]="特征值";
   excel.Cells[3,22]="权重";

   excel.get_Range(excel.Cells[ 1 , 1 ],excel.Cells[ 3 ,1 ]).MergeCells=true;
   excel.get_Range(excel.Cells[ 1 , 2 ],excel.Cells[ 1 ,22 ]).MergeCells=true;
   excel.get_Range(excel.Cells[ 1 , 23 ],excel.Cells[ 1 ,24 ]).MergeCells=true;
   excel.get_Range(excel.Cells[ 2 , 2 ],excel.Cells[ 2 ,4 ]).MergeCells=true;
   excel.get_Range(excel.Cells[ 2 , 5 ],excel.Cells[ 2 ,7 ]).MergeCells=true;
   excel.get_Range(excel.Cells[ 2 , 8],excel.Cells[ 2 ,10 ]).MergeCells=true;
   excel.get_Range(excel.Cells[ 2 ,11 ],excel.Cells[ 2 ,13 ]).MergeCells=true;
   excel.get_Range(excel.Cells[ 2 , 14 ],excel.Cells[ 2 ,16 ]).MergeCells=true;
   excel.get_Range(excel.Cells[ 2 , 17 ],excel.Cells[ 2 ,19 ]).MergeCells=true;
   excel.get_Range(excel.Cells[ 2 , 20 ],excel.Cells[ 2 ,22 ]).MergeCells=true;
   excel.get_Range(excel.Cells[ 2 , 23 ],excel.Cells[ 3 ,23 ]).MergeCells=true;
   excel.get_Range(excel.Cells[ 2 , 24 ],excel.Cells[ 3 ,24 ]).MergeCells=true;
           
   /*往Excel格式表格中写入数据*/
   int waterdataRows=myds.Tables[0].Rows.Count;
   int waterdataCols=myds.Tables[0].Columns.Count;
   for(int i=1;i<=waterdataRows;i++)
   {
    excel.Cells[i+3,1]=myds.Tables[0].Rows[i-1].ItemArray.GetValue(0);
    for(int j=1;j<=7;j++)
    {
     excel.Cells[i+3,3*j]=myds.Tables[0].Rows[i-1].ItemArray.GetValue(j);
     excel.Cells[i+3,3*j+1]=WW[j-1];     
    }
    excel.Cells[i+3,23]=ds.Tables[0].Rows[i-1].ItemArray.GetValue(1);
    excel.Cells[i+3,24]=ds.Tables[0].Rows[i-1].ItemArray.GetValue(3);
   }
   excel.Visible=false;
   excel.DisplayAlerts=false;
   //Excel.WorksheetClass worksheet=(Excel.WorksheetClass)excel.ActiveSheet;
   excel.Save();
   excel.Application.Workbooks.Close();
   excel.Application.Quit();
   excel.Quit();
   System.Runtime.InteropServices.Marshal.ReleaseComObject (excel);   
   KillProcess("EXCEL.EXE");   
   GC.Collect();




相关文章

相关软件