不依赖OFFICE组件实现带图片的EXCEL导出
2007-07-08 15:50
309 查看
现在很多的虚拟主机提供商都不提供OWC或者OFFICE,这使得我们不能通过操作Excel或者OWC的方式来生成带有饼或柱图的EXCEL文件。下面说两种可以不依赖OFFICE组件或DLL的导出方法,权当抛砖引玉:
1.使用Response.Write直接导出EXCEL
这种方式网上介绍的非常多,但大部分都是导出纯表格的,介绍导出带图片的不多。其实方法很简单,就是将图片放在Gridview里,然后导出整个Gridview就可以了,导出按钮代码如下:
protected void Button1_Click(object sender, EventArgs e)
System.IO.StringWriter SW = new System.IO.StringWriter();
//添加图片
GridViewRow dviRow = new GridViewRow(5, 5, DataControlRowType.Footer, DataControlRowState.Normal);//这里设置导出位置
TableCell tcCell = new TableCell();
Image img = new Image();//新建一个图片控件
// img.ImageUrl = "http://localhost:1141/ExcelImage/3.GIF";//这里添上要导出的图片。
string strPath = "http://" + Request.ServerVariables["server_name"] + Request.ServerVariables["script_name"].ToLower().Trim();
strPath = strPath.Replace("testintvsoffer.aspx", "Graphs/") + "Demo.gif";
tcCell.Controls.Add(img);
dviRow.Cells.Add(tcCell);
this.GridView1.Controls[0].Controls.Add(dviRow);
//以下为导出Excel(代码源于网上)
System.Web.UI.HtmlTextWriter HTW = new System.Web.UI.HtmlTextWriter(SW);
this.GridView1.RenderControl(HTW);
//Page为要导出的对象,当前是Page,如果是DataGrid,DataList等都可以
Response.Buffer = true;
Response.Clear();
Response.ClearContent();
Response.ClearHeaders();
Response.ContentType = "application/ms-excel";
//Response.ContentType是输出流的 HTTP MIME 类型
//Response.ContentType --- word文件
//application/vnd.ms-excel --- excel文件
// Response.Charset = "utf-8";
Response.ContentEncoding = System.Text.Encoding.GetEncoding("utf-8");
Response.AddHeader("Content-Disposition", "attachment;filename=XXX.xls");
//attachment --- 作为附件下载
//inline --- 在线打开
//filename如过是中文,则可以用HttpUtility.UrlEncode(fileName,System.Text.Encoding.UTF8)
//进行进行编码,以解决文件名乱码的问题
Response.Write(SW.ToString());
Response.Flush();
Response.Close();
}
上面代码会报一个异常,只需要重载VerifyRenderingInServerForm将方法清空就可以啦~
2.使用ReportViewer导出EXCEL
利用Rdlc报表和ReportViewer可以非常好的实现EXCEL和PDF的导出功能而不需要OFFICE组件的支持,而且由于RDLC设计器本身的优势,设计起来也十分方便。
注:第一种方法主要的问题就是报表图片的生成~~不知众高手一般用什么类库来做,请赐教~~
1.使用Response.Write直接导出EXCEL
这种方式网上介绍的非常多,但大部分都是导出纯表格的,介绍导出带图片的不多。其实方法很简单,就是将图片放在Gridview里,然后导出整个Gridview就可以了,导出按钮代码如下:
protected void Button1_Click(object sender, EventArgs e)
System.IO.StringWriter SW = new System.IO.StringWriter();
//添加图片
GridViewRow dviRow = new GridViewRow(5, 5, DataControlRowType.Footer, DataControlRowState.Normal);//这里设置导出位置
TableCell tcCell = new TableCell();
Image img = new Image();//新建一个图片控件
// img.ImageUrl = "http://localhost:1141/ExcelImage/3.GIF";//这里添上要导出的图片。
string strPath = "http://" + Request.ServerVariables["server_name"] + Request.ServerVariables["script_name"].ToLower().Trim();
strPath = strPath.Replace("testintvsoffer.aspx", "Graphs/") + "Demo.gif";
tcCell.Controls.Add(img);
dviRow.Cells.Add(tcCell);
this.GridView1.Controls[0].Controls.Add(dviRow);
//以下为导出Excel(代码源于网上)
System.Web.UI.HtmlTextWriter HTW = new System.Web.UI.HtmlTextWriter(SW);
this.GridView1.RenderControl(HTW);
//Page为要导出的对象,当前是Page,如果是DataGrid,DataList等都可以
Response.Buffer = true;
Response.Clear();
Response.ClearContent();
Response.ClearHeaders();
Response.ContentType = "application/ms-excel";
//Response.ContentType是输出流的 HTTP MIME 类型
//Response.ContentType --- word文件
//application/vnd.ms-excel --- excel文件
// Response.Charset = "utf-8";
Response.ContentEncoding = System.Text.Encoding.GetEncoding("utf-8");
Response.AddHeader("Content-Disposition", "attachment;filename=XXX.xls");
//attachment --- 作为附件下载
//inline --- 在线打开
//filename如过是中文,则可以用HttpUtility.UrlEncode(fileName,System.Text.Encoding.UTF8)
//进行进行编码,以解决文件名乱码的问题
Response.Write(SW.ToString());
Response.Flush();
Response.Close();
}
上面代码会报一个异常,只需要重载VerifyRenderingInServerForm将方法清空就可以啦~
2.使用ReportViewer导出EXCEL
利用Rdlc报表和ReportViewer可以非常好的实现EXCEL和PDF的导出功能而不需要OFFICE组件的支持,而且由于RDLC设计器本身的优势,设计起来也十分方便。
注:第一种方法主要的问题就是报表图片的生成~~不知众高手一般用什么类库来做,请赐教~~
相关文章推荐
- 编程经验:不依赖office组件的Excel简单导出
- 在应用程序上实现OFFICE相关的WORD EXCEL导入导出操作
- ThinkPHP 整合 PHPExcel ,数据导出功能实现,解决Invalid cell coordinate PHPExcel想必大家都不陌生,是用来操作Office Excel 文档的一个PHP
- Java程序员从笨鸟到菜鸟之(一百零四)java操作office和pdf文件(二)利用POI实现数据导出excel报表
- C# 实现Excel导出图片
- Java程序员从笨鸟到菜鸟之(一百零四)java操作office和pdf文件(二)利用POI实现数据导出excel报表
- ASP 使用office组件导出excel时乱码
- 依赖POI实现EXCEL导入数据并生成javaBean和EXCEL根据数据库表导出
- 用C#操作office组件库实现word文档的创建及文字 表格 图片的插入
- 系统不安装Office导出Excel的实现方法
- VSTS 2008 利用NPOI组件实现将 DataSource 导出成 excel
- C#通过引用Office Excel (2007) 组件实现对Excel文件的操作
- C#通过引用Office Excel (2007) 组件实现对Excel文件的操作
- Java程序员从笨鸟到菜鸟之(一百零五)java操作office和pdf文件(三)利用jxl实现数据导出excel报表以及与POI的区别
- VB.NET导出Excel 轻松实现Excel的服务器与客户端交换 服务器不安装Office
- JAVA将Excel中的报表导出为图片格式(二)实现思路
- asp.net下导出excel导出控件MyXls,不依赖微软组件,底层二进制读写
- office组件导出excel问题
- [原创]C#通过引用Office Excel (2007) 组件实现对Excel文件的操作
- 关于实现ASP导出Excel文件开关可能会碰到的组件注册问题!