其中X 代表数字,一般 9.0 以上 , 根据你的操作系统以及 office 版本而定
C#将 DataSet 中的数据写入 Excel 中
导出Excel 文件 #region 导出 Excel 文件
/**/<summary>
///导出 Excel 文件
///</summary>
///<paramname="ds">要导出的 DataSet</param>
///<paramname="strExcelFileName">要导出的文件名 </param>
privatevoidExportExcel(DataSetds,stringstrExcelFileName)
{
objectobjOpt=Missing.Value;
Applicationexcel=newApplication();
excel.Visible=true;
_Workbookwkb=excel.Workbooks.Add(objOpt);
_Worksheetwks=(_Worksheet)wkb.ActiveSheet;
wks.Visible=XlSheetVisibility.xlSheetVisible;
introwIndex=1;
intcolIndex=0;
DataTabletable=ds.Tables[0];
foreach(DataColumncolintable.Columns)
{
colIndex++;
excel.Cells[1,colIndex]=col.ColumnName;
}
foreach(DataRowrowintable.Rows)
{
rowIndex++;
colIndex=0;
foreach(DataColumncolintable.Columns)
{
colIndex++;
excel.Cells[rowIndex,colIndex]=row[col.ColumnName].ToString();
}
}
//excel.Sheets[0]="sss";
wkb.SaveAs(strExcelFileName,objOpt,null,null,false,false,XlSaveAsAccessMode.xlNoChange,null,null,null,null,null);
wkb.Close(false,objOpt,objOpt);
excel.Quit();
}
#endregion
这是一个使用Excel 中查询分析器 (Ms 通用查询分析器 ) 完成从 SQLServer7.0 以上版本 ( 已通过测试 ) 的数据快速导出到 Excel 中的示例。它由两个参数完成,其中的第一个是你所要进行查询分析时使用的 Select 查询语句。为了好看,我们给我们导出的数据加上一个名称。名称,由第二个参数传递进来:)好了,不说什么废话了。大家看代码吧。
usingSystem;
usingExcel;
namespace类库
{
publicclassExcel导出
{
publicExcel导出 (string 查询语句 ,string 标题 )
{
Excel.Applicationexcel;
Excel._WorkbookxBk;
Excel._WorksheetxSt;
Excel._QueryTablexQt;
stringConn="ODBC;DRIVER=SQLServer;SERVER=[服务器地址或者名称 ];UID=sa;PWD=[ 密码 ];APP=[ 应用程序名称 ( 一般为操作系统名 )];WSID=[ 工作站名称 ( 客户端 )];DATABASE=[ 数据库名称 ]";
stringSelect=查询语句 ;
excel=newExcel.ApplicationClass();
xBk=excel.Workbooks.Add(true);
xSt=(Excel._Worksheet)xBk.ActiveSheet;
excel.Cells[2,2]=标题 ;
xSt.get_Range(excel.Cells[2,2],excel.Cells[2,2]).Font.Bold=true;
xSt.get_Range(excel.Cells[2,2],excel.Cells[2,2]).Font.Name="黑体 ";
xSt.get_Range(excel.Cells[2,2],excel.Cells[2,2]).Font.Size=22;
xQt=xSt.QueryTables.Add(Conn,xSt.get_Range(excel.Cells[4,2],excel.Cells[4,2]),Select);
xQt.Name="导出示例 ";
xQt.FieldNames=true;
xQt.RowNumbers=false;
xQt.FillAdjacentFormulas=false;
xQt.PreserveFormatting=false;
xQt.BackgroundQuery=true;
xQt.RefreshStyle=Excel.XlCellInsertionMode.xlInsertDeleteCells;
xQt.AdjustColumnWidth=true;
xQt.RefreshPeriod=0;
xQt.PreserveColumnInfo=true;
xQt.Refresh(xQt.BackgroundQuery);
excel.Visible=true;
}
}
}
全中文的,不用进行解释了吧?
原来进行数据导出操作( 相关连接 http://www.youkuaiyun.com/Develop/Read_Article.asp?Id=21391 ),三百条记录,用时十分钟以上。如果使用 Excel 自带的这一个查询工具,导出一万条记录,只需十秒钟以内的时间,而且,可以完成格式自动排版的功能。
可能有人会问:Excel 里面的查询语句与 SQLServer 里面的查询语句是不是一样的?这里说明一点。使用这个类,可以直接使用 SQLServer 里面的查询语句,包括直接传递 SQLServer 的存储过程。
protectedvoidDoTranExcel(System.Data.DataSetExelDt)
{
intcolIndex=1,rowIndex=1;
Excel.Applicationexcel;
try
{
excel=newExcel.Application();
excel.Application.Workbooks.Add(true);
excel.Visible=true;
}
catch
{
MessageBox.Show("您可能没有安装 Office ,请安装再使用该功能 ");
return;
}
//foreach(DataColumncolinthis.ExelDt.Tables[0].Columns)
//{
//excel.Cells[1,colIndex]=col.ColumnName;colIndex++;
try
{
//}
for(inti=0;i<this.xdg.TableStyles[0].GridColumnStyles.Count;i++)
{
excel.Cells[1,colIndex]=this.xdg.TableStyles[0].GridColumnStyles[i].HeaderText;colIndex++;
}
foreach(DataRowrowinExelDt.Tables[0].Rows)
{
rowIndex++;colIndex=0;
foreach(DataColumncolinExelDt.Tables[0].Columns)
{
colIndex++;
if(colIndex==1)
{
excel.Cells[rowIndex,colIndex]="'"+row[col.ColumnName].ToString();
}
else
{
excel.Cells[rowIndex,colIndex]=row[col.ColumnName].ToString();
}
}
}
}
catch(System.Exception)
{
MessageBox.Show("输出 Excel 有错误,请确认没有关闭 Excel");
return;
}
}