原创-Asp.net导出word的方法总结(利用response.write方式将html模板导出word,和dsoframer导出word)
最近做项目用到了将整个页面导出word,原来用的dsoframer,发现导出的时候格式不是很好,随找了一个html模板方式导出word,现写出来供大家参考,并将步骤说与大家:
1、新建一个word文档,做成一个模板,需要填充数据库内容的地方用诸如{Year}的方式标记。
2、点击文件--另存为网页,起一个名字。比如xx.htm,关闭。
3、打开刚刚保存的htm文件,打开方式选择word,你会发现。打开的时候视图方式改为了 web,这让我们开着很不爽,虽然打印的时候没啥问题,但是总是感觉不爽,经过研究,发现可以这么操作,点击视图页面,这个word文档就变成了视图方式,合乎常理的,但是现在保存再打开,发现word一点没改变,别着急,重新打开这个模板文档,然后点击视图页面--随便在页面上打一个空格,然后保存,就可以了。哈
4、对于cs的页面文件,我把内容贴出来
protected void btnShow_Click( object sender, EventArgs e ) { string strWord = ExprotMissionToWord( Server.MapPath( "~/download/magazineturn.htm" ) ); //Response Word File To Client Response.ContentEncoding = System.Text.Encoding.UTF7; Response.ClearContent(); Response.ClearHeaders(); Response.AddHeader( "content-disposition", "attachment;filename=magazineturn.doc" ); //必须的 Response.AddHeader( "Content-type", "application" ); Response.ContentType = "application/ms-html"; Response.ContentEncoding = System.Text.Encoding.Default; //如果不行改为utf7,默认一般可以,处理头部乱码的问题 Response.Write( strWord ); Response.Flush(); Response.Close(); } public string ExprotMissionToWord( string templatePath ) { StringBuilder sb = new StringBuilder( 1024 ); if (Request["magazineTurnID"] == null) { WebUtilities.HandleMessage( this.Page, "对不起,未流转的不能导出" ); } else { MagazineTurn mt = this.magazineTurnService.GetMagazineTurnByID( Request["magazineTurnID"].ToString() ); StreamReader sr = new StreamReader( templatePath, Encoding.Default ); sb.Append( sr.ReadToEnd() ); sr.Close(); sb.Replace( "{Year}", mt.DCreatedTime.ToString( "yyyy" ) ); sb.Replace( "{Issue}", mt.Id ); sb.Replace( "{SourceID}", mt.SourceID ); sb.Replace( "{Content}", mt.TurnContent ); sb.Replace( "{FromUnit}", this.unitInfoService.Get( mt.TurnFromUnitName ).Name ); sb.Replace( "{FromUser}", mt.TurnFromUserName ); sb.Replace( "{LeaderReplay}", mt.TurnLeaderReplay ); sb.Replace( "{ToUnit}", this.unitInfoService.Get( mt.TurnToUnitName ).Name ); sb.Replace( "{LimitTime}", mt.TurnLimitTime.ToString("yyyy年MM月dd日 HH:mm:ss") ); sb.Replace( "{FeedBackResults}", mt.TurnFeedBackResults ); sb.Replace( "{FeedBacker}", mt.TurnFeedBacker ); sb.Replace( "{responsibility}", mt.TurnToUserName ); } return sb.ToString(); }
模板文件
二、dsoframer的方式晚上再弄吧。赶紧工作了