魔幻☆天空

  博客园 :: 首页 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
  16 随笔 :: 0 文章 :: 21 评论 :: 0 Trackbacks

    现在很多的虚拟主机提供商都不提供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(55, 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设计器本身的优势,设计起来也十分方便。



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

posted on 2007-07-08 15:50 魔幻天空 阅读(2411) 评论(8)  编辑 收藏

评论

好像这样保存的格式不是Excel本身的格式吧?
  回复  引用    

#2楼  2007-07-08 16:20 birdshome      
dundas
  回复  引用  查看    

#3楼  2007-07-08 16:41 魔幻天空      
@Frank[CallFrank@gmail.com]
的确如此,是多一个提示,但打开没有问题~
  回复  引用  查看    

#4楼  2007-07-08 22:44 曲滨*銘龘鶽      
1)
图片,不就是加一个
<img src=""....
标签吗?

  回复  引用  查看    

#5楼  2007-07-09 00:21 S.Sams      
这样输出 Excel 文件, 并非真正意义上的 .xls 文件, 只是一个HTML文件, 可以加 Img 标签 , 路径指向 公网绝对地址 http:// ***.gif 即可!
  回复  引用  查看    

#6楼  2007-07-09 12:21 web报表      
使用e表内带有ebexcel.dll可以实现,ebexcel.dll实现了直接对excel文件进行二进制层面的读写,客户端和服务器端都无需要安装ms excel.详细情况见: http://webreport.cnblogs.com/
  回复  引用  查看    

#7楼  2007-08-07 10:44 Clark Zheng      
@魔幻天空
报表图片我用ZedGraph生成,是个开源项目,不过功能比较简单
  回复  引用  查看    

#8楼  2007-08-17 17:32 小点 [未注册用户]
直接用Response.ContentType = "application/vnd.ms-excel"
来定义输出内容的头,可以直接将当前网页显示的内容以excel文档形式下载
  回复  引用    


标题  
姓名  
主页
Email (只有博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
 
另存  打印