• 本文介绍下,C#实现的可以导出与导入excel的代码一例,有需要的朋友,参考下吧。

      C#实现导出与导入excel。
      代码1:
       
      复制代码 代码示例:
      #region  导出Excel  
      /// <summary>  
      /// 导出Excel  
      /// </summary>  
      /// <param name="page">请求的页面this</param>  
      /// <param name="dataTable">导出的数据源</param>  
      /// <param name="fileName">保存文件名称</param>  
      /// <returns>布尔值</returns>  
      public bool ExportExcel(Page page, DataTable dataTable, string fileName)  
      {  
          try  
          {  
              HttpContext.Current.Response.Clear();  
              HttpContext.Current.Response.Buffer = true;  
              HttpContext.Current.Response.ContentType = "application/vnd.ms-excel.numberformat:@";  
              page.EnableViewState = false;  
              HttpContext.Current.Response.Charset = "UTF-8";  
              HttpContext.Current.Response.ContentEncoding = System.Text.Encoding.GetEncoding("gb2312");//设置输出流为简体中文  
              HttpContext.Current.Response.AppendHeader("Content-Disposition", "attachment;filename=" + fileName + ".xls");  
              //输出列名  
              for (int i = 0; i < dataTable.Columns.Count; i++)  
                HttpContext.Current.Response.Write(dataTable.Columns[i].ColumnName + "\t");  
                HttpContext.Current.Response.Write("\r\n");  
                //输出数据  
              for (int i = 0; i < dataTable.Rows.Count; i++)  
              {  
      for (int j = 0; j < dataTable.Columns.Count; j++)  
      {  
          HttpContext.Current.Response.Write(dataTable.Rows[i][j].ToString() + "\t");  
      }  
      HttpContext.Current.Response.Write("\r\n");  
              }  
              //输出当前缓存内容  
              //HttpContext.Current.Response.Flush();  
              HttpContext.Current.Response.End();  
              return true;  
          }  
          catch  
          {  
              return false;  
          }  
      }  
      #endregion

      代码2
       
      代码示例:
      #region 导出Excel 自定义格式  
      /// <summary>  
      /// 导出Excel    
      /// 1.文本:vnd.ms-excel.numberformat:@  
      /// 2.日期:vnd.ms-excel.numberformat:yyyy/mm/dd  
      /// 3.数字:vnd.ms-excel.numberformat:#,##0.00  
      /// 4.货币:vnd.ms-excel.numberformat:¥#,##0.00  
      /// 5.百分比:vnd.ms-excel.numberformat: #0.00%  
      /// </summary>  
      /// <param name="fileName"></param>  
      /// <param name="dt"></param>  
      /// <returns></returns>  
      public bool Export(string fileName, DataTable dt)  
      {  
         try  
         {  
             HttpResponse resp;  
             resp = System.Web.HttpContext.Current.Response;  
             resp.ContentEncoding = System.Text.Encoding.GetEncoding("utf-8");  
             resp.AppendHeader("Content-Disposition", "attachment;filename=" + fileName + ".xls");  
             resp.AppendHeader("Content-Type", "application/ms-excel");  
            
             StringBuilder colHeaders = new StringBuilder();  
             StringBuilder ls_item = new StringBuilder();  
             DataRow[] myRow = dt.Select();  
             int cl = dt.Columns.Count;  
            
             colHeaders.Append(" <html><head> \n ");  
             colHeaders.Append(" <meta http-equiv='Content-Type' content='text/html; charset=gb2312' /> \n ");  
             colHeaders.Append(" </head> \n ");  
             colHeaders.Append(" <body> \n ");  
             colHeaders.Append(" <table border='1'> ");  
             colHeaders.Append(" <tr> ");  
             //输出列名  
             for (int i = 0; i < dt.Columns.Count; i++)  
      colHeaders.Append("<td  style='background-color:#CCCCCC'>" + dt.Columns[i].ColumnName + "</td>");  
             colHeaders.Append("</tr> ");  
             resp.Write(colHeaders.ToString());  
             foreach (DataRow row in myRow)  
             {  
      ls_item.Append("<tr>");  
      for (int i = 0; i < cl; i++)  
      {  
         if (i == (cl - 1))  
         {  
             ls_item.Append("<td style='vnd.ms-excel.numberformat:@ '>" + row[i].ToString() + "</td>" + "\n");  
         }  
         else  
         {  
             ls_item.Append("<td style= 'vnd.ms-excel.numberformat:@ '>" + row[i].ToString() + "</td>");  
         }  
      }  
      ls_item.Append("</tr>");  
             }  
             ls_item.Append(" </table> \n ");  
             ls_item.Append(" </body> \n ");  
             ls_item.Append(" </html>");  
             resp.Write(ls_item.ToString());  
             resp.End();  
             return true;  
         }  
         catch  
         {  
             return false;  
         }  
      }  
      #endregion 
      代码3
       
      代码示例:
      #region 导入Excel  
      public string ImportExcel(string[] list, string filePath)  
      {  
              string isXls = System.IO.Path.GetExtension(filePath).ToLower(); //System.IO.Path.GetExtension获得文件的扩展名  
              if (isXls != ".xls")  
              return "请选择Excel文件导入!";  
              DataSet ds = ExecleDataSet(filePath); //调用自定义方法  
              DataRow[] dr = ds.Tables[0].Select(); //定义一个DataRow数组  
              int rowsnum = ds.Tables[0].Rows.Count;  
              if (ds.Tables[0].Rows.Count == 0)  
              return "Excel无数据!";  
              return "";  
          }  
            
          //OleDB连接读取Excel中数据  
          public DataSet ExecleDataSet(string filePath)  
          {  
              string OleDbConnection = "Provider=Microsoft.Jet.OleDb.4.0;" + "data source=" + filePath + ";Extended Properties='Excel 8.0; HDR=YES; IMEX=1'";  
              OleDbConnection conn = new OleDbConnection(OleDbConnection);  
              conn.Open();  
              DataSet ds = new DataSet();  
              OleDbDataAdapter odda = new OleDbDataAdapter("select * from [Sheet1$]", conn);  
              odda.Fill(ds);  
              conn.Close();  
              return ds;  
      }  
      #endregion

    • 转载自:http://www.hello-code.com/blog/asp.net/201401/2645.html

ASP.NET导入导出Excel方法大全的更多相关文章

  1. .NET导入导出Excel方法总结

    最近,应项目的需求,需要实现Excel的导入导出功能,对于Web架构的Excel导入导出功能,比较传统的实现方式是: 1)导入Excel:将Excel文件上传到服务器的某一文件夹下,然后在服务端完成E ...

  2. PHP导入导出Excel方法

    看到这篇文章的时候,很是惊讶原作者的耐心,虽然我们在平时用的也 有一些,但没有作者列出来的全,写excel的时候,我用过pear的库,也用过pack压包的头,同样那些利用smarty等作的简单替换xm ...

  3. c# 导入导出excel方法封装

    在很多项目中,都会使用到文件的上传下载等,为了方便,封装了一个帮助类,每次直接拿过来使用就可以了,下面是封装的类和使用方法. using Common.AttributeHelper; using N ...

  4. PHP导入导出Excel方法小结

    基本上导出的文件分为两种: 1:类Excel格式,这个其实不是传统意义上的Excel文件,只是因为Excel的兼容能力强,能够正确打开而已.修改这种文件后再保存,通常会提示你是否要转换成Excel文件 ...

  5. ASP.NET常用导出Excel方法汇总

    本文转载:http://mattberseth.com/blog/2007/04/export_gridview_to_excel_1.html http://geekswithblogs.net/a ...

  6. asp.net中导出Excel的方法

    一.asp.net中导出Excel的方法: 本文转载 在asp.net中导出Excel有两种方法,一种是将导出的文件存放在服务器某个文件夹下面,然后将文件地址输出在浏览器上:一种是将文件直接将文件输出 ...

  7. ASP.NET Core导入导出Excel文件

    ASP.NET Core导入导出Excel文件 希望在ASP.NET Core中导入导出Excel文件,在网上搜了一遍,基本都是使用EPPlus插件,EPPlus挺好用,但商用需要授权,各位码友若有好 ...

  8. ASP.NET Core 导入导出Excel xlsx 文件

    ASP.NET Core 使用EPPlus.Core导入导出Excel xlsx 文件,EPPlus.Core支持Excel 2007/2010 xlsx文件导入导出,可以运行在Windows, Li ...

  9. .Net MVC 导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) 通过MVC控制器导出导入Excel文件(可用于java SSH架构)

    .Net MVC  导入导出Excel总结(三种导出Excel方法,一种导入Excel方法) [原文地址] 通过MVC控制器导出导入Excel文件(可用于java SSH架构)   public cl ...

随机推荐

  1. Java 练习题摘录

    2018-01-21 23:23:08 1.finally与return同时出现的情况 finally中有return语句则会使try...catch中的return语句失效 public stati ...

  2. SpringBoot下的值注入

    在我们实际开发项目中,经常会遇到一些常量的配置,比如url,暂时不会改变的字段参数,这个时候我们最好是不要直接写死在代码里的,因为这样编写的程序,应用扩展性太差了,我们可以直接写在配置文件中然后通过配 ...

  3. Graphviz(转载)

    简述 原文: http://www.tuicool.com/articles/vy2Ajyu 本文翻译自 Drawing Graphs using Dot and Graphviz 1. 许可 Cop ...

  4. 十三 web爬虫讲解2—Scrapy框架爬虫—Scrapy爬取百度新闻,爬取Ajax动态生成的信息

    crapy爬取百度新闻,爬取Ajax动态生成的信息,抓取百度新闻首页的新闻rul地址 有多网站,当你浏览器访问时看到的信息,在html源文件里却找不到,由得信息还是滚动条滚动到对应的位置后才显示信息, ...

  5. IOS-下载动画

    就2小时教会你抽丝剥茧CAAnimation核心动画之精美的下载动画 header 设计灵感 设计此效果的作者 Nick; images 开始之前你需要了解的 先上一张CAAnimation层次图: ...

  6. my.cnf 参数说明

    [mysql] prompt="\\u@\\h:\p  \\R:\\m:\\s [\\d]>"  The prompt command reconfigures the de ...

  7. 015PHP基础知识——流程控制(三)

    <?php /** *流程控制(三) */ /* 循环结构: while(){ } */ //设置脚本最长执行时间:100秒 //set_time_limit(100); $lantian = ...

  8. 通过fork进程爆破canary

    1.1.1    通过fork进程爆破canary ⑴.原理分析: 对fork而言,作用相当于自我复制,每一次复制出来的程序,内存布局都是一样的,当然canary值也一样.那我们就可以逐位爆破,如果程 ...

  9. win10 downloader.exe 修复方法

    由于系统更新是和系统密切相关的,在日常使用中某些系统文件如果出现损坏,同样会导致系统更新无法成功安装.如果在使用Windows 10时可以成功下载更新,但是安装的时候出错,此时就需要对系统文件进行检查 ...

  10. 【python】matplotlib进阶

    参考文章:https://liam0205.me/2014/09/11/matplotlib-tutorial-zh-cn/ 几个重要对象:图像.子图.坐标轴.记号 figure:图像, subplo ...