在做.NET项目时,经常会遇到要导出文件的问题,如将DataGrid中的数据导出到word、excel文件等。下面是自己写的一个.net导出文件操作类,现把代码贴出来,以供参考,如有不当之处望予指正!
 
        
    
        在做.NET项目时,经常会遇到要导出文件的问题,如将DataGrid中的数据导出到word、excel文件等。
下面是自己写的一个.net导出文件操作类,现把代码贴出来,以供参考,如有不当之处望予指正!

 .net导出文件操作类
.net导出文件操作类
1 using System;
using System;
2 using System.Web;
using System.Web;
3 namespace FLX.ComplexQuery
namespace FLX.ComplexQuery
4

 {
{
5
 /**//// <summary>
    /**//// <summary>
6 /// 彭建军
    /// 彭建军
7 /// 导出报表数据存入word或execl文件
    /// 导出报表数据存入word或execl文件
8 /// 2008-06-19
    /// 2008-06-19
9 /// </summary>
    /// </summary>
10 public class ExportData
    public class ExportData
11
 
     {
{
12
 构造函数#region 构造函数
        构造函数#region 构造函数
13 public ExportData()
        public ExportData()
14
 
         {
{
15 //
            //
16 // TODO: 在此处添加构造函数逻辑
            // TODO: 在此处添加构造函数逻辑
17 //
            //
18 }
        }
19 #endregion
        #endregion
20
21
 导出页面或web控件方法#region 导出页面或web控件方法
        导出页面或web控件方法#region 导出页面或web控件方法
22
 /**//// <summary>
        /**//// <summary>
23 /// 将Web控件或页面信息导出(不带文件名参数)
        /// 将Web控件或页面信息导出(不带文件名参数)
24 /// </summary>
        /// </summary>
25 /// <param name="source">控件实例</param>
        /// <param name="source">控件实例</param>        
26 /// <param name="DocumentType">导出类型:Excel或Word</param>
        /// <param name="DocumentType">导出类型:Excel或Word</param>
27 public void ExportControl(System.Web.UI.Control source, string DocumentType)
        public void ExportControl(System.Web.UI.Control source, string DocumentType)
28
 
         {
{
29 //设置Http的头信息,编码格式
            //设置Http的头信息,编码格式
30 if (DocumentType == "Excel")
            if (DocumentType == "Excel")
31
 
             {
{
32 //Excel
                //Excel            
33 HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode("下载文件.xls",System.Text.Encoding.UTF8));
                HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode("下载文件.xls",System.Text.Encoding.UTF8));
34 HttpContext.Current.Response.ContentType = "application/ms-excel";
                HttpContext.Current.Response.ContentType = "application/ms-excel";
35 }
            }
36
37 else if (DocumentType == "Word")
            else if (DocumentType == "Word")
38
 
             {
{
39 //Word
                //Word
40 HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode("下载文件.doc",System.Text.Encoding.UTF8));
                HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode("下载文件.doc",System.Text.Encoding.UTF8));
41 HttpContext.Current.Response.ContentType = "application/ms-word";
                HttpContext.Current.Response.ContentType = "application/ms-word";
42 }
            }
43
44 HttpContext.Current.Response.Charset = "UTF-8";
            HttpContext.Current.Response.Charset = "UTF-8";   
45 HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.UTF8;
            HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.UTF8; 
46
47 //关闭控件的视图状态
            //关闭控件的视图状态
48 source.Page.EnableViewState =false;
            source.Page.EnableViewState =false;    
49
50 //初始化HtmlWriter
            //初始化HtmlWriter
51 System.IO.StringWriter writer = new System.IO.StringWriter() ;
            System.IO.StringWriter writer = new System.IO.StringWriter() ;
52 System.Web.UI.HtmlTextWriter htmlWriter = new System.Web.UI.HtmlTextWriter(writer);
            System.Web.UI.HtmlTextWriter htmlWriter = new System.Web.UI.HtmlTextWriter(writer);
53 source.RenderControl(htmlWriter);
            source.RenderControl(htmlWriter); 
54
55 //输出
            //输出
56 HttpContext.Current.Response.Write(writer.ToString());
            HttpContext.Current.Response.Write(writer.ToString());
57 HttpContext.Current.Response.End();
            HttpContext.Current.Response.End();
58 }
        }
59
60
 /**//// <summary>
        /**//// <summary>
61 /// 将Web控件或页面信息导出(带文件名参数)
        /// 将Web控件或页面信息导出(带文件名参数)
62 /// </summary>
        /// </summary>
63 /// <param name="source">控件实例</param>
        /// <param name="source">控件实例</param>        
64 /// <param name="DocumentType">导出类型:Excel或Word</param>
        /// <param name="DocumentType">导出类型:Excel或Word</param>
65 /// <param name="filename">保存文件名</param>
        /// <param name="filename">保存文件名</param>
66 public void ExportControl(System.Web.UI.Control source, string DocumentType, string filename)
        public void ExportControl(System.Web.UI.Control source, string DocumentType, string filename)
67
 
         {
{
68 //设置Http的头信息,编码格式
            //设置Http的头信息,编码格式
69 if (DocumentType == "Excel")
            if (DocumentType == "Excel")
70
 
             {
{
71 //Excel
                //Excel            
72 HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode(filename+".xls",System.Text.Encoding.UTF8));
                HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode(filename+".xls",System.Text.Encoding.UTF8));
73 HttpContext.Current.Response.ContentType = "application/ms-excel";
                HttpContext.Current.Response.ContentType = "application/ms-excel";            
74 }
            }
75
76 else if (DocumentType == "Word")
            else if (DocumentType == "Word")
77
 
             {
{
78 //Word
                //Word
79 HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode(filename+".doc",System.Text.Encoding.UTF8));
                HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode(filename+".doc",System.Text.Encoding.UTF8));
80 HttpContext.Current.Response.ContentType = "application/ms-word";
                HttpContext.Current.Response.ContentType = "application/ms-word";
81 }
            }
82
83 HttpContext.Current.Response.Charset = "UTF-8";
            HttpContext.Current.Response.Charset = "UTF-8";   
84 HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.UTF8;
            HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.UTF8; 
85
86 //关闭控件的视图状态
            //关闭控件的视图状态
87 source.Page.EnableViewState =false;
            source.Page.EnableViewState =false;    
88
89 //初始化HtmlWriter
            //初始化HtmlWriter
90 System.IO.StringWriter writer = new System.IO.StringWriter() ;
            System.IO.StringWriter writer = new System.IO.StringWriter() ;
91 System.Web.UI.HtmlTextWriter htmlWriter = new System.Web.UI.HtmlTextWriter(writer);
            System.Web.UI.HtmlTextWriter htmlWriter = new System.Web.UI.HtmlTextWriter(writer);
92 source.RenderControl(htmlWriter);
            source.RenderControl(htmlWriter); 
93
94 //输出
            //输出
95 HttpContext.Current.Response.Write(writer.ToString());
            HttpContext.Current.Response.Write(writer.ToString());
96 HttpContext.Current.Response.End();
            HttpContext.Current.Response.End();
97 }
        }
98 #endregion
        #endregion
99
100
 调用说明#region 调用说明
        调用说明#region 调用说明
101 //方法ExportControl(System.Web.UI.Control source, string DocumentType,string filename)中
        //方法ExportControl(System.Web.UI.Control source, string DocumentType,string filename)中
102 //第一个参数source表示导出的页面或控件名,当为datagrid或dataList控件时,在导出Excel/word文件时,必须把控件的分页、排序等属性去除并重新绑定,
        //第一个参数source表示导出的页面或控件名,当为datagrid或dataList控件时,在导出Excel/word文件时,必须把控件的分页、排序等属性去除并重新绑定,
103 //第二个参数DocumentType表示导出的文件类型word或excel
        //第二个参数DocumentType表示导出的文件类型word或excel
104 //第三个参数filename表示需要导出的文件所取的文件名
        //第三个参数filename表示需要导出的文件所取的文件名
105 //调用方法:
        //调用方法:
106 //ExportData export=new ExportData();
        //ExportData export=new ExportData();
107 //export.ExportControl(this, "Word","testfilename");//当为this时表示当前页面
        //export.ExportControl(this, "Word","testfilename");//当为this时表示当前页面
108 //这是将整个页面导出为Word,并命名为testfilename
        //这是将整个页面导出为Word,并命名为testfilename
109 #endregion
        #endregion
110 }
    }
111 }
}
112 
    
说明一下,类中的HttpContext.Current.Response.ContentType表示要导出文件的类型,
下面是对Response.ContentType类型的汇总
    

 Response.ContentType类型汇总
Response.ContentType类型汇总
 在ASP.NET中使用Response.ContentType="类型名";来确定输出格式
在ASP.NET中使用Response.ContentType="类型名";来确定输出格式 
 'ez' => 'application/andrew-inset',
'ez' => 'application/andrew-inset',  
 'hqx' => 'application/mac-binhex40',
'hqx' => 'application/mac-binhex40',  
 'cpt' => 'application/mac-compactpro',
'cpt' => 'application/mac-compactpro',  
 'doc' => 'application/msword',
'doc' => 'application/msword',  
 'bin' => 'application/octet-stream',
'bin' => 'application/octet-stream',  
 'dms' => 'application/octet-stream',
'dms' => 'application/octet-stream',  
 'lha' => 'application/octet-stream',
'lha' => 'application/octet-stream',  
 'lzh' => 'application/octet-stream',
'lzh' => 'application/octet-stream',  
 'exe' => 'application/octet-stream',
'exe' => 'application/octet-stream',  
 'class' => 'application/octet-stream',
'class' => 'application/octet-stream',  
 'so' => 'application/octet-stream',
'so' => 'application/octet-stream',  
 'dll' => 'application/octet-stream',
'dll' => 'application/octet-stream',  
 'oda' => 'application/oda',
'oda' => 'application/oda',  
 'pdf' => 'application/pdf',
'pdf' => 'application/pdf',  
 'ai' => 'application/postscript',
'ai' => 'application/postscript',  
 'eps' => 'application/postscript',
'eps' => 'application/postscript',  
 'ps' => 'application/postscript',
'ps' => 'application/postscript',  
 'smi' => 'application/smil',
'smi' => 'application/smil',  
 'smil' => 'application/smil',
'smil' => 'application/smil',  
 'mif' => 'application/vnd.mif',
'mif' => 'application/vnd.mif',  
 'xls' => 'application/vnd.ms-excel',
'xls' => 'application/vnd.ms-excel',  
 'ppt' => 'application/vnd.ms-powerpoint',
'ppt' => 'application/vnd.ms-powerpoint',  
 'wbxml' => 'application/vnd.wap.wbxml',
'wbxml' => 'application/vnd.wap.wbxml',  
 'wmlc' => 'application/vnd.wap.wmlc',
'wmlc' => 'application/vnd.wap.wmlc',  
 'wmlsc' => 'application/vnd.wap.wmlscriptc',
'wmlsc' => 'application/vnd.wap.wmlscriptc',  
 'bcpio' => 'application/x-bcpio',
'bcpio' => 'application/x-bcpio',  
 'vcd' => 'application/x-cdlink',
'vcd' => 'application/x-cdlink',  
 'pgn' => 'application/x-chess-pgn',
'pgn' => 'application/x-chess-pgn',  
 'cpio' => 'application/x-cpio',
'cpio' => 'application/x-cpio',  
 'csh' => 'application/x-csh',
'csh' => 'application/x-csh',  
 'dcr' => 'application/x-director',
'dcr' => 'application/x-director',  
 'dir' => 'application/x-director',
'dir' => 'application/x-director',  
 'dxr' => 'application/x-director',
'dxr' => 'application/x-director',  
 'dvi' => 'application/x-dvi',
'dvi' => 'application/x-dvi',  
 'spl' => 'application/x-futuresplash',
'spl' => 'application/x-futuresplash',  
 'gtar' => 'application/x-gtar',
'gtar' => 'application/x-gtar',  
 'hdf' => 'application/x-hdf',
'hdf' => 'application/x-hdf',  
 'js' => 'application/x-javascript',
'js' => 'application/x-javascript',  
 'skp' => 'application/x-koan',
'skp' => 'application/x-koan',  
 'skd' => 'application/x-koan',
'skd' => 'application/x-koan',  
 'skt' => 'application/x-koan',
'skt' => 'application/x-koan',  
 'skm' => 'application/x-koan',
'skm' => 'application/x-koan',  
 'latex' => 'application/x-latex',
'latex' => 'application/x-latex',  
 'nc' => 'application/x-netcdf',
'nc' => 'application/x-netcdf',  
 'cdf' => 'application/x-netcdf',
'cdf' => 'application/x-netcdf',  
 'sh' => 'application/x-sh',
'sh' => 'application/x-sh',  
 'shar' => 'application/x-shar',
'shar' => 'application/x-shar',  
 'swf' => 'application/x-shockwave-flash',
'swf' => 'application/x-shockwave-flash',  
 'sit' => 'application/x-stuffit',
'sit' => 'application/x-stuffit',  
 'sv4cpio' => 'application/x-sv4cpio',
'sv4cpio' => 'application/x-sv4cpio',  
 'sv4crc' => 'application/x-sv4crc',
'sv4crc' => 'application/x-sv4crc',  
 'tar' => 'application/x-tar',
'tar' => 'application/x-tar',  
 'tcl' => 'application/x-tcl',
'tcl' => 'application/x-tcl',  
 'tex' => 'application/x-tex',
'tex' => 'application/x-tex',  
 'texinfo' => 'application/x-texinfo',
'texinfo' => 'application/x-texinfo',  
 'texi' => 'application/x-texinfo',
'texi' => 'application/x-texinfo',  
 't' => 'application/x-troff',
't' => 'application/x-troff',  
 'tr' => 'application/x-troff',
'tr' => 'application/x-troff',  
 'roff' => 'application/x-troff',
'roff' => 'application/x-troff',  
 'man' => 'application/x-troff-man',
'man' => 'application/x-troff-man',  
 'me' => 'application/x-troff-me',
'me' => 'application/x-troff-me',  
 'ms' => 'application/x-troff-ms',
'ms' => 'application/x-troff-ms',  
 'ustar' => 'application/x-ustar',
'ustar' => 'application/x-ustar',  
 'src' => 'application/x-wais-source',
'src' => 'application/x-wais-source',  
 'xhtml' => 'application/xhtml+xml',
'xhtml' => 'application/xhtml+xml',  
 'xht' => 'application/xhtml+xml',
'xht' => 'application/xhtml+xml',  
 'zip' => 'application/zip',
'zip' => 'application/zip',  
 'au' => 'audio/basic',
'au' => 'audio/basic',  
 'snd' => 'audio/basic',
'snd' => 'audio/basic',  
 'mid' => 'audio/midi',
'mid' => 'audio/midi',  
 'midi' => 'audio/midi',
'midi' => 'audio/midi',  
 'kar' => 'audio/midi',
'kar' => 'audio/midi',  
 'mpga' => 'audio/mpeg',
'mpga' => 'audio/mpeg',  
 'mp2' => 'audio/mpeg',
'mp2' => 'audio/mpeg',  
 'mp3' => 'audio/mpeg',
'mp3' => 'audio/mpeg',  
 'aif' => 'audio/x-aiff',
'aif' => 'audio/x-aiff',  
 'aiff' => 'audio/x-aiff',
'aiff' => 'audio/x-aiff',  
 'aifc' => 'audio/x-aiff',
'aifc' => 'audio/x-aiff',  
 'm3u' => 'audio/x-mpegurl',
'm3u' => 'audio/x-mpegurl',  
 'ram' => 'audio/x-pn-realaudio',
'ram' => 'audio/x-pn-realaudio',  
 'rm' => 'audio/x-pn-realaudio',
'rm' => 'audio/x-pn-realaudio',  
 'rpm' => 'audio/x-pn-realaudio-plugin',
'rpm' => 'audio/x-pn-realaudio-plugin',  
 'ra' => 'audio/x-realaudio',
'ra' => 'audio/x-realaudio',  
 'wav' => 'audio/x-wav',
'wav' => 'audio/x-wav',  
 'pdb' => 'chemical/x-pdb',
'pdb' => 'chemical/x-pdb',  
 'xyz' => 'chemical/x-xyz',
'xyz' => 'chemical/x-xyz',  
 'bmp' => 'image/bmp',
'bmp' => 'image/bmp',  
 'gif' => 'image/gif',
'gif' => 'image/gif',  
 'ief' => 'image/ief',
'ief' => 'image/ief',  
 'jpeg' => 'image/jpeg',
'jpeg' => 'image/jpeg',  
 'jpg' => 'image/jpeg',
'jpg' => 'image/jpeg',  
 'jpe' => 'image/jpeg',
'jpe' => 'image/jpeg',  
 'png' => 'image/png',
'png' => 'image/png',  
 'tiff' => 'image/tiff',
'tiff' => 'image/tiff',  
 'tif' => 'image/tiff',
'tif' => 'image/tiff',  
 'djvu' => 'image/vnd.djvu',
'djvu' => 'image/vnd.djvu',  
 'djv' => 'image/vnd.djvu',
'djv' => 'image/vnd.djvu',  
 'wbmp' => 'image/vnd.wap.wbmp',
'wbmp' => 'image/vnd.wap.wbmp',  
 'ras' => 'image/x-cmu-raster',
'ras' => 'image/x-cmu-raster',  
 'pnm' => 'image/x-portable-anymap',
'pnm' => 'image/x-portable-anymap',  
 'pbm' => 'image/x-portable-bitmap',
'pbm' => 'image/x-portable-bitmap',  
 'pgm' => 'image/x-portable-graymap',
'pgm' => 'image/x-portable-graymap',  
 'ppm' => 'image/x-portable-pixmap',
'ppm' => 'image/x-portable-pixmap',  
 'rgb' => 'image/x-rgb',
'rgb' => 'image/x-rgb',  
 'xbm' => 'image/x-xbitmap',
'xbm' => 'image/x-xbitmap',  
 'xpm' => 'image/x-xpixmap',
'xpm' => 'image/x-xpixmap',  
 'xwd' => 'image/x-xwindowdump',
'xwd' => 'image/x-xwindowdump',  
 'igs' => 'model/iges',
'igs' => 'model/iges',  
 'iges' => 'model/iges',
'iges' => 'model/iges',  
 'msh' => 'model/mesh',
'msh' => 'model/mesh',  
 'mesh' => 'model/mesh',
'mesh' => 'model/mesh',  
 'silo' => 'model/mesh',
'silo' => 'model/mesh',  
 'wrl' => 'model/vrml',
'wrl' => 'model/vrml',  
 'vrml' => 'model/vrml',
'vrml' => 'model/vrml',  
 'css' => 'text/css',
'css' => 'text/css',  
 'html' => 'text/html',
'html' => 'text/html',  
 'htm' => 'text/html',
'htm' => 'text/html',  
 'asc' => 'text/plain',
'asc' => 'text/plain',  
 'txt' => 'text/plain',
'txt' => 'text/plain',  
 'rtx' => 'text/richtext',
'rtx' => 'text/richtext',  
 'rtf' => 'text/rtf',
'rtf' => 'text/rtf',  
 'sgml' => 'text/sgml',
'sgml' => 'text/sgml',  
 'sgm' => 'text/sgml',
'sgm' => 'text/sgml',  
 'tsv' => 'text/tab-separated-values',
'tsv' => 'text/tab-separated-values',  
 'wml' => 'text/vnd.wap.wml',
'wml' => 'text/vnd.wap.wml',  
 'wmls' => 'text/vnd.wap.wmlscript',
'wmls' => 'text/vnd.wap.wmlscript',  
 'etx' => 'text/x-setext',
'etx' => 'text/x-setext',  
 'xsl' => 'text/xml',
'xsl' => 'text/xml',  
 'xml' => 'text/xml',
'xml' => 'text/xml',  
 'mpeg' => 'video/mpeg',
'mpeg' => 'video/mpeg',  
 'mpg' => 'video/mpeg',
'mpg' => 'video/mpeg',  
 'mpe' => 'video/mpeg',
'mpe' => 'video/mpeg',  
 'qt' => 'video/quicktime',
'qt' => 'video/quicktime',  
 'mov' => 'video/quicktime',
'mov' => 'video/quicktime',  
 'mxu' => 'video/vnd.mpegurl',
'mxu' => 'video/vnd.mpegurl',  
 'avi' => 'video/x-msvideo',
'avi' => 'video/x-msvideo',  
 'movie' => 'video/x-sgi-movie',
'movie' => 'video/x-sgi-movie',  
 'ice' => 'x-conference/x-cooltalk'
'ice' => 'x-conference/x-cooltalk'  
   
下面是自己写的一个.net导出文件操作类,现把代码贴出来,以供参考,如有不当之处望予指正!

 .net导出文件操作类
.net导出文件操作类1
 using System;
using System;2
 using System.Web;
using System.Web;3
 namespace FLX.ComplexQuery
namespace FLX.ComplexQuery4


 {
{5

 /**//// <summary>
    /**//// <summary>6
 /// 彭建军
    /// 彭建军7
 /// 导出报表数据存入word或execl文件
    /// 导出报表数据存入word或execl文件8
 /// 2008-06-19
    /// 2008-06-199
 /// </summary>
    /// </summary>10
 public class ExportData
    public class ExportData11

 
     {
{12

 构造函数#region 构造函数
        构造函数#region 构造函数13
 public ExportData()
        public ExportData()14

 
         {
{15
 //
            //16
 // TODO: 在此处添加构造函数逻辑
            // TODO: 在此处添加构造函数逻辑17
 //
            //18
 }
        }19
 #endregion
        #endregion20

21

 导出页面或web控件方法#region 导出页面或web控件方法
        导出页面或web控件方法#region 导出页面或web控件方法22

 /**//// <summary>
        /**//// <summary>23
 /// 将Web控件或页面信息导出(不带文件名参数)
        /// 将Web控件或页面信息导出(不带文件名参数)24
 /// </summary>
        /// </summary>25
 /// <param name="source">控件实例</param>
        /// <param name="source">控件实例</param>        26
 /// <param name="DocumentType">导出类型:Excel或Word</param>
        /// <param name="DocumentType">导出类型:Excel或Word</param>27
 public void ExportControl(System.Web.UI.Control source, string DocumentType)
        public void ExportControl(System.Web.UI.Control source, string DocumentType)28

 
         {
{29
 //设置Http的头信息,编码格式
            //设置Http的头信息,编码格式30
 if (DocumentType == "Excel")
            if (DocumentType == "Excel")31

 
             {
{32
 //Excel
                //Excel            33
 HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode("下载文件.xls",System.Text.Encoding.UTF8));
                HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode("下载文件.xls",System.Text.Encoding.UTF8));34
 HttpContext.Current.Response.ContentType = "application/ms-excel";
                HttpContext.Current.Response.ContentType = "application/ms-excel";35
 }
            }36

37
 else if (DocumentType == "Word")
            else if (DocumentType == "Word")38

 
             {
{39
 //Word
                //Word40
 HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode("下载文件.doc",System.Text.Encoding.UTF8));
                HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode("下载文件.doc",System.Text.Encoding.UTF8));41
 HttpContext.Current.Response.ContentType = "application/ms-word";
                HttpContext.Current.Response.ContentType = "application/ms-word";42
 }
            }43

44
 HttpContext.Current.Response.Charset = "UTF-8";
            HttpContext.Current.Response.Charset = "UTF-8";   45
 HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.UTF8;
            HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.UTF8; 46

47
 //关闭控件的视图状态
            //关闭控件的视图状态48
 source.Page.EnableViewState =false;
            source.Page.EnableViewState =false;    49

50
 //初始化HtmlWriter
            //初始化HtmlWriter51
 System.IO.StringWriter writer = new System.IO.StringWriter() ;
            System.IO.StringWriter writer = new System.IO.StringWriter() ;52
 System.Web.UI.HtmlTextWriter htmlWriter = new System.Web.UI.HtmlTextWriter(writer);
            System.Web.UI.HtmlTextWriter htmlWriter = new System.Web.UI.HtmlTextWriter(writer);53
 source.RenderControl(htmlWriter);
            source.RenderControl(htmlWriter); 54

55
 //输出
            //输出56
 HttpContext.Current.Response.Write(writer.ToString());
            HttpContext.Current.Response.Write(writer.ToString());57
 HttpContext.Current.Response.End();
            HttpContext.Current.Response.End();58
 }
        }59

60

 /**//// <summary>
        /**//// <summary>61
 /// 将Web控件或页面信息导出(带文件名参数)
        /// 将Web控件或页面信息导出(带文件名参数)62
 /// </summary>
        /// </summary>63
 /// <param name="source">控件实例</param>
        /// <param name="source">控件实例</param>        64
 /// <param name="DocumentType">导出类型:Excel或Word</param>
        /// <param name="DocumentType">导出类型:Excel或Word</param>65
 /// <param name="filename">保存文件名</param>
        /// <param name="filename">保存文件名</param>66
 public void ExportControl(System.Web.UI.Control source, string DocumentType, string filename)
        public void ExportControl(System.Web.UI.Control source, string DocumentType, string filename)67

 
         {
{68
 //设置Http的头信息,编码格式
            //设置Http的头信息,编码格式69
 if (DocumentType == "Excel")
            if (DocumentType == "Excel")70

 
             {
{71
 //Excel
                //Excel            72
 HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode(filename+".xls",System.Text.Encoding.UTF8));
                HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode(filename+".xls",System.Text.Encoding.UTF8));73
 HttpContext.Current.Response.ContentType = "application/ms-excel";
                HttpContext.Current.Response.ContentType = "application/ms-excel";            74
 }
            }75

76
 else if (DocumentType == "Word")
            else if (DocumentType == "Word")77

 
             {
{78
 //Word
                //Word79
 HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode(filename+".doc",System.Text.Encoding.UTF8));
                HttpContext.Current.Response.AppendHeader("Content-Disposition","attachment;filename="+ HttpUtility.UrlEncode(filename+".doc",System.Text.Encoding.UTF8));80
 HttpContext.Current.Response.ContentType = "application/ms-word";
                HttpContext.Current.Response.ContentType = "application/ms-word";81
 }
            }82

83
 HttpContext.Current.Response.Charset = "UTF-8";
            HttpContext.Current.Response.Charset = "UTF-8";   84
 HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.UTF8;
            HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.UTF8; 85

86
 //关闭控件的视图状态
            //关闭控件的视图状态87
 source.Page.EnableViewState =false;
            source.Page.EnableViewState =false;    88

89
 //初始化HtmlWriter
            //初始化HtmlWriter90
 System.IO.StringWriter writer = new System.IO.StringWriter() ;
            System.IO.StringWriter writer = new System.IO.StringWriter() ;91
 System.Web.UI.HtmlTextWriter htmlWriter = new System.Web.UI.HtmlTextWriter(writer);
            System.Web.UI.HtmlTextWriter htmlWriter = new System.Web.UI.HtmlTextWriter(writer);92
 source.RenderControl(htmlWriter);
            source.RenderControl(htmlWriter); 93

94
 //输出
            //输出95
 HttpContext.Current.Response.Write(writer.ToString());
            HttpContext.Current.Response.Write(writer.ToString());96
 HttpContext.Current.Response.End();
            HttpContext.Current.Response.End();97
 }
        }98
 #endregion
        #endregion99

100

 调用说明#region 调用说明
        调用说明#region 调用说明101
 //方法ExportControl(System.Web.UI.Control source, string DocumentType,string filename)中
        //方法ExportControl(System.Web.UI.Control source, string DocumentType,string filename)中102
 //第一个参数source表示导出的页面或控件名,当为datagrid或dataList控件时,在导出Excel/word文件时,必须把控件的分页、排序等属性去除并重新绑定,
        //第一个参数source表示导出的页面或控件名,当为datagrid或dataList控件时,在导出Excel/word文件时,必须把控件的分页、排序等属性去除并重新绑定,103
 //第二个参数DocumentType表示导出的文件类型word或excel
        //第二个参数DocumentType表示导出的文件类型word或excel104
 //第三个参数filename表示需要导出的文件所取的文件名
        //第三个参数filename表示需要导出的文件所取的文件名105
 //调用方法:
        //调用方法:106
 //ExportData export=new ExportData();
        //ExportData export=new ExportData();107
 //export.ExportControl(this, "Word","testfilename");//当为this时表示当前页面
        //export.ExportControl(this, "Word","testfilename");//当为this时表示当前页面108
 //这是将整个页面导出为Word,并命名为testfilename
        //这是将整个页面导出为Word,并命名为testfilename109
 #endregion
        #endregion110
 }
    }111
 }
}112

说明一下,类中的HttpContext.Current.Response.ContentType表示要导出文件的类型,
下面是对Response.ContentType类型的汇总

 Response.ContentType类型汇总
Response.ContentType类型汇总 在ASP.NET中使用Response.ContentType="类型名";来确定输出格式
在ASP.NET中使用Response.ContentType="类型名";来确定输出格式  'ez' => 'application/andrew-inset',
'ez' => 'application/andrew-inset',   'hqx' => 'application/mac-binhex40',
'hqx' => 'application/mac-binhex40',   'cpt' => 'application/mac-compactpro',
'cpt' => 'application/mac-compactpro',   'doc' => 'application/msword',
'doc' => 'application/msword',   'bin' => 'application/octet-stream',
'bin' => 'application/octet-stream',   'dms' => 'application/octet-stream',
'dms' => 'application/octet-stream',   'lha' => 'application/octet-stream',
'lha' => 'application/octet-stream',   'lzh' => 'application/octet-stream',
'lzh' => 'application/octet-stream',   'exe' => 'application/octet-stream',
'exe' => 'application/octet-stream',   'class' => 'application/octet-stream',
'class' => 'application/octet-stream',   'so' => 'application/octet-stream',
'so' => 'application/octet-stream',   'dll' => 'application/octet-stream',
'dll' => 'application/octet-stream',   'oda' => 'application/oda',
'oda' => 'application/oda',   'pdf' => 'application/pdf',
'pdf' => 'application/pdf',   'ai' => 'application/postscript',
'ai' => 'application/postscript',   'eps' => 'application/postscript',
'eps' => 'application/postscript',   'ps' => 'application/postscript',
'ps' => 'application/postscript',   'smi' => 'application/smil',
'smi' => 'application/smil',   'smil' => 'application/smil',
'smil' => 'application/smil',   'mif' => 'application/vnd.mif',
'mif' => 'application/vnd.mif',   'xls' => 'application/vnd.ms-excel',
'xls' => 'application/vnd.ms-excel',   'ppt' => 'application/vnd.ms-powerpoint',
'ppt' => 'application/vnd.ms-powerpoint',   'wbxml' => 'application/vnd.wap.wbxml',
'wbxml' => 'application/vnd.wap.wbxml',   'wmlc' => 'application/vnd.wap.wmlc',
'wmlc' => 'application/vnd.wap.wmlc',   'wmlsc' => 'application/vnd.wap.wmlscriptc',
'wmlsc' => 'application/vnd.wap.wmlscriptc',   'bcpio' => 'application/x-bcpio',
'bcpio' => 'application/x-bcpio',   'vcd' => 'application/x-cdlink',
'vcd' => 'application/x-cdlink',   'pgn' => 'application/x-chess-pgn',
'pgn' => 'application/x-chess-pgn',   'cpio' => 'application/x-cpio',
'cpio' => 'application/x-cpio',   'csh' => 'application/x-csh',
'csh' => 'application/x-csh',   'dcr' => 'application/x-director',
'dcr' => 'application/x-director',   'dir' => 'application/x-director',
'dir' => 'application/x-director',   'dxr' => 'application/x-director',
'dxr' => 'application/x-director',   'dvi' => 'application/x-dvi',
'dvi' => 'application/x-dvi',   'spl' => 'application/x-futuresplash',
'spl' => 'application/x-futuresplash',   'gtar' => 'application/x-gtar',
'gtar' => 'application/x-gtar',   'hdf' => 'application/x-hdf',
'hdf' => 'application/x-hdf',   'js' => 'application/x-javascript',
'js' => 'application/x-javascript',   'skp' => 'application/x-koan',
'skp' => 'application/x-koan',   'skd' => 'application/x-koan',
'skd' => 'application/x-koan',   'skt' => 'application/x-koan',
'skt' => 'application/x-koan',   'skm' => 'application/x-koan',
'skm' => 'application/x-koan',   'latex' => 'application/x-latex',
'latex' => 'application/x-latex',   'nc' => 'application/x-netcdf',
'nc' => 'application/x-netcdf',   'cdf' => 'application/x-netcdf',
'cdf' => 'application/x-netcdf',   'sh' => 'application/x-sh',
'sh' => 'application/x-sh',   'shar' => 'application/x-shar',
'shar' => 'application/x-shar',   'swf' => 'application/x-shockwave-flash',
'swf' => 'application/x-shockwave-flash',   'sit' => 'application/x-stuffit',
'sit' => 'application/x-stuffit',   'sv4cpio' => 'application/x-sv4cpio',
'sv4cpio' => 'application/x-sv4cpio',   'sv4crc' => 'application/x-sv4crc',
'sv4crc' => 'application/x-sv4crc',   'tar' => 'application/x-tar',
'tar' => 'application/x-tar',   'tcl' => 'application/x-tcl',
'tcl' => 'application/x-tcl',   'tex' => 'application/x-tex',
'tex' => 'application/x-tex',   'texinfo' => 'application/x-texinfo',
'texinfo' => 'application/x-texinfo',   'texi' => 'application/x-texinfo',
'texi' => 'application/x-texinfo',   't' => 'application/x-troff',
't' => 'application/x-troff',   'tr' => 'application/x-troff',
'tr' => 'application/x-troff',   'roff' => 'application/x-troff',
'roff' => 'application/x-troff',   'man' => 'application/x-troff-man',
'man' => 'application/x-troff-man',   'me' => 'application/x-troff-me',
'me' => 'application/x-troff-me',   'ms' => 'application/x-troff-ms',
'ms' => 'application/x-troff-ms',   'ustar' => 'application/x-ustar',
'ustar' => 'application/x-ustar',   'src' => 'application/x-wais-source',
'src' => 'application/x-wais-source',   'xhtml' => 'application/xhtml+xml',
'xhtml' => 'application/xhtml+xml',   'xht' => 'application/xhtml+xml',
'xht' => 'application/xhtml+xml',   'zip' => 'application/zip',
'zip' => 'application/zip',   'au' => 'audio/basic',
'au' => 'audio/basic',   'snd' => 'audio/basic',
'snd' => 'audio/basic',   'mid' => 'audio/midi',
'mid' => 'audio/midi',   'midi' => 'audio/midi',
'midi' => 'audio/midi',   'kar' => 'audio/midi',
'kar' => 'audio/midi',   'mpga' => 'audio/mpeg',
'mpga' => 'audio/mpeg',   'mp2' => 'audio/mpeg',
'mp2' => 'audio/mpeg',   'mp3' => 'audio/mpeg',
'mp3' => 'audio/mpeg',   'aif' => 'audio/x-aiff',
'aif' => 'audio/x-aiff',   'aiff' => 'audio/x-aiff',
'aiff' => 'audio/x-aiff',   'aifc' => 'audio/x-aiff',
'aifc' => 'audio/x-aiff',   'm3u' => 'audio/x-mpegurl',
'm3u' => 'audio/x-mpegurl',   'ram' => 'audio/x-pn-realaudio',
'ram' => 'audio/x-pn-realaudio',   'rm' => 'audio/x-pn-realaudio',
'rm' => 'audio/x-pn-realaudio',   'rpm' => 'audio/x-pn-realaudio-plugin',
'rpm' => 'audio/x-pn-realaudio-plugin',   'ra' => 'audio/x-realaudio',
'ra' => 'audio/x-realaudio',   'wav' => 'audio/x-wav',
'wav' => 'audio/x-wav',   'pdb' => 'chemical/x-pdb',
'pdb' => 'chemical/x-pdb',   'xyz' => 'chemical/x-xyz',
'xyz' => 'chemical/x-xyz',   'bmp' => 'image/bmp',
'bmp' => 'image/bmp',   'gif' => 'image/gif',
'gif' => 'image/gif',   'ief' => 'image/ief',
'ief' => 'image/ief',   'jpeg' => 'image/jpeg',
'jpeg' => 'image/jpeg',   'jpg' => 'image/jpeg',
'jpg' => 'image/jpeg',   'jpe' => 'image/jpeg',
'jpe' => 'image/jpeg',   'png' => 'image/png',
'png' => 'image/png',   'tiff' => 'image/tiff',
'tiff' => 'image/tiff',   'tif' => 'image/tiff',
'tif' => 'image/tiff',   'djvu' => 'image/vnd.djvu',
'djvu' => 'image/vnd.djvu',   'djv' => 'image/vnd.djvu',
'djv' => 'image/vnd.djvu',   'wbmp' => 'image/vnd.wap.wbmp',
'wbmp' => 'image/vnd.wap.wbmp',   'ras' => 'image/x-cmu-raster',
'ras' => 'image/x-cmu-raster',   'pnm' => 'image/x-portable-anymap',
'pnm' => 'image/x-portable-anymap',   'pbm' => 'image/x-portable-bitmap',
'pbm' => 'image/x-portable-bitmap',   'pgm' => 'image/x-portable-graymap',
'pgm' => 'image/x-portable-graymap',   'ppm' => 'image/x-portable-pixmap',
'ppm' => 'image/x-portable-pixmap',   'rgb' => 'image/x-rgb',
'rgb' => 'image/x-rgb',   'xbm' => 'image/x-xbitmap',
'xbm' => 'image/x-xbitmap',   'xpm' => 'image/x-xpixmap',
'xpm' => 'image/x-xpixmap',   'xwd' => 'image/x-xwindowdump',
'xwd' => 'image/x-xwindowdump',   'igs' => 'model/iges',
'igs' => 'model/iges',   'iges' => 'model/iges',
'iges' => 'model/iges',   'msh' => 'model/mesh',
'msh' => 'model/mesh',   'mesh' => 'model/mesh',
'mesh' => 'model/mesh',   'silo' => 'model/mesh',
'silo' => 'model/mesh',   'wrl' => 'model/vrml',
'wrl' => 'model/vrml',   'vrml' => 'model/vrml',
'vrml' => 'model/vrml',   'css' => 'text/css',
'css' => 'text/css',   'html' => 'text/html',
'html' => 'text/html',   'htm' => 'text/html',
'htm' => 'text/html',   'asc' => 'text/plain',
'asc' => 'text/plain',   'txt' => 'text/plain',
'txt' => 'text/plain',   'rtx' => 'text/richtext',
'rtx' => 'text/richtext',   'rtf' => 'text/rtf',
'rtf' => 'text/rtf',   'sgml' => 'text/sgml',
'sgml' => 'text/sgml',   'sgm' => 'text/sgml',
'sgm' => 'text/sgml',   'tsv' => 'text/tab-separated-values',
'tsv' => 'text/tab-separated-values',   'wml' => 'text/vnd.wap.wml',
'wml' => 'text/vnd.wap.wml',   'wmls' => 'text/vnd.wap.wmlscript',
'wmls' => 'text/vnd.wap.wmlscript',   'etx' => 'text/x-setext',
'etx' => 'text/x-setext',   'xsl' => 'text/xml',
'xsl' => 'text/xml',   'xml' => 'text/xml',
'xml' => 'text/xml',   'mpeg' => 'video/mpeg',
'mpeg' => 'video/mpeg',   'mpg' => 'video/mpeg',
'mpg' => 'video/mpeg',   'mpe' => 'video/mpeg',
'mpe' => 'video/mpeg',   'qt' => 'video/quicktime',
'qt' => 'video/quicktime',   'mov' => 'video/quicktime',
'mov' => 'video/quicktime',   'mxu' => 'video/vnd.mpegurl',
'mxu' => 'video/vnd.mpegurl',   'avi' => 'video/x-msvideo',
'avi' => 'video/x-msvideo',   'movie' => 'video/x-sgi-movie',
'movie' => 'video/x-sgi-movie',   'ice' => 'x-conference/x-cooltalk'
'ice' => 'x-conference/x-cooltalk'   
                    
                     
                    
                 
                    
                 
 
         
                
            
         浙公网安备 33010602011771号
浙公网安备 33010602011771号