首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > asp.net >

100分,怎么在ASP.NET2.0中把GridView中的数据导出到excel文件中

2012-02-09 
100分求助,如何在ASP.NET2.0中把GridView中的数据导出到excel文件中?哪位高手给解答下重谢[解决办法]priva

100分求助,如何在ASP.NET2.0中把GridView中的数据导出到excel文件中?
哪位高手给解答下
重谢

[解决办法]
private void Export(string FileType, string FileName) 
{//導出Excel 
Response.Charset = "Big5"; 
Response.ContentEncoding = System.Text.Encoding.UTF7; 
Response.AppendHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(FileName, Encoding.UTF8).ToString()); 
Response.ContentType = FileType; 
this.EnableViewState = false; 
StringWriter tw = new StringWriter(); 
HtmlTextWriter hw = new HtmlTextWriter(tw); 
GridView1.RenderControl(hw); 
Response.Write(tw.ToString()); 
Response.End(); 

public override void VerifyRenderingInServerForm(Control control) 



**.aspx页面中要加:EnableEventValidation = "false"
[解决办法]
使用CarlosAg.ExcelXmlWriter.dll第三方控件.
请参看:CarlosAg.ExcelXmlWriter实现.net下Excel导出功能(服务端不需要安装Excel程序)

[解决办法]
asp.net里导出excel表方法汇总
http://www.cnblogs.com/zrlhappy/articles/496033.html
[解决办法]
引用excel
public class ExportToExcel
{

私有成员#region 私有成员
// 数据的DataView
private DataView dv=null;

// 表格标题
private string title=null;

// 输出文件路径
private string outFilePath=null;


// 输入文件名
private string inputFilePath=System.Windows.Forms.Application.StartupPath+@" emplate.xls";

#endregion

公共属性#region 公共属性
/**//// <summary>
/// 数据的DataView
/// </summary>
public DataView DV
{
set
{
dv=value;
}
}

/**//// <summary>
/// 表格标题
/// </summary>
public string Title
{
set
{
title=value;
}
get
{
return title;
}
}

/**//// <summary>
/// 输出文件路径
/// </summary>
public string OutFilePath
{
set
{
outFilePath=value;
}
get
{
return outFilePath;
}
}

/**//// <summary>
/// 输入文件路径
/// </summary>
private string InputFilePath
{
set
{
inputFilePath=value;
}
get
{
return inputFilePath;
}
}

#endregion

构造函数#region 构造函数

public ExportToExcel()
{
}

// public OutputExcel(DataView dv,string title)
// {
//
// }

#endregion

公共方法#region 公共方法
/**///
public void CreateExcel()
{
int rowIndex=4;//行起始坐标
int colIndex=1;//列起始坐标

ApplicationClass myApp=null;
Workbook myBook=null;
Worksheet mySheet=null;

//如果文件不存在,则将模板文件拷贝一份作为输出文件
if(!File.Exists(outFilePath))


{
File.Copy(inputFilePath,outFilePath,true);
}

myApp= new ApplicationClass();
myApp.Visible=false;
object oMissiong=System.Reflection.Missing.Value;
myApp.Workbooks.Open(outFilePath,oMissiong,oMissiong,oMissiong,oMissiong,
oMissiong,oMissiong,oMissiong,oMissiong,oMissiong,oMissiong,oMissiong,
oMissiong,oMissiong,oMissiong);
myBook=myApp.Workbooks[1];
mySheet=(Worksheet)myBook.ActiveSheet;

//取得标题
foreach(DataColumn col in dv.Table.Columns)
{
colIndex++;
mySheet.Cells[4,colIndex] = col.ColumnName;
mySheet.get_Range(mySheet.Cells[4,colIndex],mySheet.Cells[4,colIndex]).HorizontalAlignment = XlVAlign.xlVAlignCenter;//设置标题格式为居中对齐
}

//取得表格中的数据
foreach(DataRowView row in dv)
{
rowIndex ++;
colIndex = 1;
foreach(DataColumn col in dv.Table.Columns)
{
colIndex ++;
if(col.DataType == System.Type.GetType("System.DateTime"))
{
mySheet.Cells[rowIndex,colIndex] = (Convert.ToDateTime(row[col.ColumnName].ToString())).ToString("yyyy-MM-dd");
mySheet.get_Range(mySheet.Cells[rowIndex,colIndex],mySheet.Cells[rowIndex,colIndex]).HorizontalAlignment = XlVAlign.xlVAlignCenter;//设置日期型的字段格式为居中对齐
}
else if(col.DataType == System.Type.GetType("System.String"))
{
mySheet.Cells[rowIndex,colIndex] = "'"+row[col.ColumnName].ToString();
mySheet.get_Range(mySheet.Cells[rowIndex,colIndex],mySheet.Cells[rowIndex,colIndex]).HorizontalAlignment = XlVAlign.xlVAlignCenter;//设置字符型的字段格式为居中对齐
}
else
{
mySheet.Cells[rowIndex,colIndex] = row[col.ColumnName].ToString();
}
}
}

//加载一个合计行
int rowSum = rowIndex + 1;
int colSum = 2;
mySheet.Cells[rowSum,2] = "合计";
mySheet.get_Range(mySheet.Cells[rowSum,2],mySheet.Cells[rowSum,2]).HorizontalAlignment = XlHAlign.xlHAlignCenter;

//设置选中的部分的颜色
mySheet.get_Range(mySheet.Cells[rowSum,colSum],mySheet.Cells[rowSum,colIndex]).Select();
mySheet.get_Range(mySheet.Cells[rowSum,colSum],mySheet.Cells[rowSum,colIndex]).Interior.ColorIndex = 19;//设置为浅黄色,共计有56种

//取得整个报表的标题
mySheet.Cells[2,2] = title;

//设置整个报表的标题格式
mySheet.get_Range(mySheet.Cells[2,2],mySheet.Cells[2,2]).Font.Bold = true;
mySheet.get_Range(mySheet.Cells[2,2],mySheet.Cells[2,2]).Font.Size = 22;

//设置报表表格为最适应宽度
mySheet.get_Range(mySheet.Cells[4,2],mySheet.Cells[rowSum,colIndex]).Select();
mySheet.get_Range(mySheet.Cells[4,2],mySheet.Cells[rowSum,colIndex]).Columns.AutoFit();

//设置整个报表的标题为跨列居中
mySheet.get_Range(mySheet.Cells[2,2],mySheet.Cells[2,colIndex]).Select();
mySheet.get_Range(mySheet.Cells[2,2],mySheet.Cells[2,colIndex]).HorizontalAlignment = XlHAlign.xlHAlignCenterAcrossSelection;

//绘制边框
mySheet.get_Range(mySheet.Cells[4,2],mySheet.Cells[rowSum,colIndex]).Borders.LineStyle = 1;
mySheet.get_Range(mySheet.Cells[4,2],mySheet.Cells[rowSum,2]).Borders[XlBordersIndex.xlEdgeLeft].Weight = XlBorderWeight.xlThick;//设置左边线加粗
mySheet.get_Range(mySheet.Cells[4,2],mySheet.Cells[4,colIndex]).Borders[XlBordersIndex.xlEdgeTop].Weight = XlBorderWeight.xlThick;//设置上边线加粗


mySheet.get_Range(mySheet.Cells[4,colIndex],mySheet.Cells[rowSum,colIndex]).Borders[XlBordersIndex.xlEdgeRight].Weight = XlBorderWeight.xlThick;//设置右边线加粗
mySheet.get_Range(mySheet.Cells[rowSum,2],mySheet.Cells[rowSum,colIndex]).Borders[XlBordersIndex.xlEdgeBottom].Weight = XlBorderWeight.xlThick;//设置下边线加粗
myBook.Save();
myBook.Close( true,outFilePath,true);

System.Runtime.InteropServices.Marshal.ReleaseComObject(mySheet);
System.Runtime.InteropServices.Marshal.ReleaseComObject(myBook);
System.Runtime.InteropServices.Marshal.ReleaseComObject(myApp);

myApp.Quit();
GC.Collect();
}
#endregion


}

[解决办法]
mark

热点排行