不依赖OFFICE组件实现带图片的EXCEL导出

    现在很多的虚拟主机提供商都不提供OWC或者OFFICE,这使得我们不能通过操作Excel或者OWC的方式来生成带有饼或柱图的EXCEL文件。下面说两种可以不依赖OFFICE组件或DLL的导出方法,权当抛砖引玉:

    1.使用Response.Write直接导出EXCEL


     这种方式网上介绍的非常多,但大部分都是导出纯表格的,介绍导出带图片的不多。其实方法很简单,就是将图片放在Gridview里,然后导出整个Gridview就可以了,导出按钮代码如下:

None.gif    protected   void  Button1_Click( object  sender, EventArgs e)
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        System.IO.StringWriter SW 
= new System.IO.StringWriter();
InBlock.gif        
//添加图片
InBlock.gif
        GridViewRow dviRow = new GridViewRow(55, DataControlRowType.Footer, DataControlRowState.Normal);//这里设置导出位置
InBlock.gif
        TableCell tcCell = new TableCell();
InBlock.gif        Image img 
= new Image();//新建一个图片控件
InBlock.gif        
// img.ImageUrl = "http://localhost:1141/ExcelImage/3.GIF";//这里添上要导出的图片。
InBlock.gif
        string strPath = "http://" + Request.ServerVariables["server_name"+ Request.ServerVariables["script_name"].ToLower().Trim();
InBlock.gif        strPath 
= strPath.Replace("testintvsoffer.aspx""Graphs/"+ "Demo.gif";
InBlock.gif        tcCell.Controls.Add(img);
InBlock.gif        dviRow.Cells.Add(tcCell);
InBlock.gif        
this.GridView1.Controls[0].Controls.Add(dviRow);
InBlock.gif        
//以下为导出Excel(代码源于网上)
InBlock.gif
        System.Web.UI.HtmlTextWriter HTW = new System.Web.UI.HtmlTextWriter(SW);
InBlock.gif        
this.GridView1.RenderControl(HTW);
InBlock.gif        
//Page为要导出的对象,当前是Page,如果是DataGrid,DataList等都可以
InBlock.gif
        Response.Buffer = true;
InBlock.gif        Response.Clear();
InBlock.gif        Response.ClearContent();
InBlock.gif        Response.ClearHeaders();
InBlock.gif        Response.ContentType 
= "application/ms-excel";
InBlock.gif        
//Response.ContentType是输出流的 HTTP MIME 类型
InBlock.gif        
//Response.ContentType     --- word文件
InBlock.gif        
//application/vnd.ms-excel --- excel文件
InBlock.gif        
//dot.gif
InBlock.gif
        Response.Charset = "utf-8";
InBlock.gif        Response.ContentEncoding 
= System.Text.Encoding.GetEncoding("utf-8");
InBlock.gif        Response.AddHeader(
"Content-Disposition""attachment;filename=XXX.xls");
InBlock.gif        
//attachment --- 作为附件下载
InBlock.gif        
//inline --- 在线打开
InBlock.gif        
//filename如过是中文,则可以用HttpUtility.UrlEncode(fileName,System.Text.Encoding.UTF8)
InBlock.gif        
//进行进行编码,以解决文件名乱码的问题
InBlock.gif
        Response.Write(SW.ToString());
InBlock.gif        Response.Flush();
InBlock.gif        Response.Close();
ExpandedBlockEnd.gif    }


上面代码会报一个异常,只需要重载VerifyRenderingInServerForm将方法清空就可以啦~

2.使用ReportViewer导出EXCEL

利用Rdlc报表和ReportViewer可以非常好的实现EXCEL和PDF的导出功能而不需要OFFICE组件的支持,而且由于RDLC设计器本身的优势,设计起来也十分方便。



注:第一种方法主要的问题就是报表图片的生成~~不知众高手一般用什么类库来做,请赐教~~

转载于:https://www.cnblogs.com/Magicsky/archive/2007/07/08/810274.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值