原创-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的方式晚上再弄吧。赶紧工作了
posted @ 2012-04-16 11:57  倚楼听雨  阅读(3864)  评论(14编辑  收藏  举报