。net报表学习-Excel导出
1 、Excel表格:
(1) 基本介绍
在asp.net中导出Execl有两种方法,一种是将导出的文件存放在服务器某个文件夹下面,然后将文件地址输出在浏览器上;一种是将文件直接将文件输出流写给浏览器。在Response输出时,\t分隔的数据,导出execl时,等价于分列,\n等价于换行。
(2) .net中导出Execl
a、将整个html全部输出execl:此法将html中所有的内容,如按钮,表格,图片等全部输出到Execl中。
代码: Response.Clear();
Response.Buffer= true;
Response.AppendHeader("Content-Disposition","attachment;filename="+DateTime.Now.ToString("yyyyMMdd")+".xls");
Response.ContentEncoding=System.Text.Encoding.UTF8;
Response.ContentType = "application/vnd.ms-excel";
this.EnableViewState = false;
说明:这里我们利用了ContentType属性,它默认的属性为text/html,这时将输出为超文本,即我们常见的网页格式到客户端,如果改为ms-excel将将输出excel格式,也就是说以电子表格的格式输出到客户端,这时浏览器将提示你下载保存。ContentType的属性还包括:image/JPEG;text/HTML;image/GIF;vnd.ms-excel/msword 。同理,我们也可以输出(导出)图片、word文档等。下面的方法,也均用了这个属性。
示例:见当前学习部分\13、Demo\net\20110409-通用报表解决方案\SimpleSolution\CommApplication\CatchWebInfo。
b、将数据控件中的数据导出Execl:上述方法虽然实现了导出的功能,但同时把按钮、分页框等html中的所有输出信息导了进去。而我们一般要导出的是数据,数据控件上的数据。
代码:DGToExcel(datagrid1)。
public void DGToExcel(System.Web.UI.Control ctl)
{
HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename=Excel.xls");
HttpContext.Current.Response.Charset ="UTF-8";
HttpContext.Current.Response.ContentEncoding =System.Text.Encoding.Default;
HttpContext.Current.Response.ContentType ="application/ms-excel";
ctl.Page.EnableViewState =false;
System.IO.StringWriter tw = new System.IO.StringWriter() ;
System.Web.UI.HtmlTextWriter hw = new System.Web.UI.HtmlTextWriter (tw);
ctl.RenderControl(hw);
HttpContext.Current.Response.Write(tw.ToString());
HttpContext.Current.Response.End();
}
说明:如果你用了分页,它导出的是当前页的信息,也就是它导出的是显示的信息。而不是你select语句的全部信息,如果出现“控件必须放在具有 runat=server 的窗体标记内"错误的解决方法”错误则需要在页面中重写Page基类的VerifyRenderingInServerForm方法,原因是“发送回或依赖于注册的脚本块的控件应该在 Control.Render 方法的重写中调用此方法”。
示例:见当前学习部分\13、Demo\net\20110409-通用报表解决方案\SimpleSolution\CommApplication\CatchWebInfo。
c、将DataSet中的数据导出Execl:有了上边的思路,就是将在导出的信息,输出(Response)客户端,这样就可以导出了。那么把DataSet中的数据导出,也就是把DataSet中的表中的各行信息,以ms-excel的格式Response到http流,这样就OK了。说明:参数ds应为填充有数据表的DataSet,文件名是全名,包括后缀名,如execl2006.xls。
代码:public void CreateExcel(DataSet ds,string FileName)
{
HttpResponse resp;
resp = Page.Response;
resp.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");
resp.AppendHeader("Content-Disposition", "attachment;filename="+FileName);
string colHeaders= "", ls_item="";
//定义表对象与行对象,同时用DataSet对其值进行初始化
DataTable dt=ds.Tables[0];
DataRow[] myRow=dt.Select();//可以类似dt.Select("id>10")之形式达到数据筛选目的
int i=0;
int cl=dt.Columns.Count;
//取得数据表各列标题,各标题之间以\t分割,最后一个列标题后加回车符
for(i=0;i<cl;i++)
{
if(i==(cl-1))//最后一列,加\n
{
colHeaders +=dt.Columns[i].Caption.ToString() +"\n";
}
else
{
colHeaders+=dt.Columns[i].Caption.ToString()+"\t";
}
}
resp.Write(colHeaders);
//向HTTP输出流中写入取得的数据信息
//逐行处理数据
foreach(DataRow row in myRow)
{
//当前行数据写入HTTP输出流,并且置空ls_item以便下行数据
for(i=0;i<cl;i++)
{
if(i==(cl-1))//最后一列,加\n
{
ls_item +=row[i].ToString()+"\n";
}
else
{
ls_item+=row[i].ToString()+"\t";
}
}
resp.Write(ls_item);
ls_item="";
}
resp.End();
}。
d、dataview导出execl:若想实现更加富于变化或者行列不规则的execl导出时,可用本法。
代码:见DEMO。
说明:命名空间-Microsoft.Office.Interop.Excel
2、简单Flash报表:
(1) 基本介绍
向flash提供所需要的xml数据即可。
(2) 关键步骤
a、见demo。
说明:注意xml格式即可。
3、简单水晶报表:
(1) 基本介绍
水晶报表(Crystal Report)是业内最专业、功能最强的报表系统,它除了强大的报表功能外,最大的优势是实现了与绝大多数流行开发工具的集成和接口。在VS.Net平台做过报表开发的程序员,一定都对水晶报表强大、高效、集成等特性留下了深刻印象。 除了开发新程序外,在工作中我们常需要接触到很多较早的软件系统报表功能升级的需求,如果能结合水晶报表这一强大的工具,往往能事半功倍。。
(2) 相关知识
a、数据绑定的2种模式:简单的说一种是推模式,一种是拉模式。
说明:Push推模式,指你已经把数据读出来放到一个数据集中了,然后把这个数据集作为报表的数据源绑定上去。
Pull拉模式,指报表在显示之前跟据你设定的SQL或是存诸过程,通过报到ADO到数据库去取数据。
(3) 关键步骤
a、见demo。
说明:注意xml格式即可。