<sup id="sjju3"><noscript id="sjju3"></noscript></sup>
    <big id="sjju3"></big>

  • <blockquote id="sjju3"></blockquote>
    <blockquote id="sjju3"></blockquote>

      <td id="sjju3"></td>

      <big id="sjju3"></big>
        <code id="sjju3"><strong id="sjju3"><dl id="sjju3"></dl></strong></code>
      1. asp.net上传Excel文件并读取数据的实现方法

         更新时间:2019年03月07日 09:47:29   作者:willingtolove   我要评论

        这篇文章主要给大家介绍了关于asp.net上传Excel文件并读取数据的实现方法,文中通过示例代码以及图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

        前言

        本文主要给大家介绍了关于asp.net上传Excel文件并读取数据的相关内容,分享出来供大家参考学习,下面?#23433;?#22810;说了,来一起看看详细的介绍吧

        实现如下:

        前台代码:使用服务端控件实现上传

          <form id="form1" runat="server">
           <div>
            <asp:FileUpload ID="ExcelFileUpload" runat="server" />
            <asp:Button ID="UploadBtn" runat="server" Text="确定上传" OnClick="UploadBtn_Click" />
           </div>
          </form>

        服务端代码:

        protected void UploadBtn_Click(object sender, EventArgs e)
        {
         if (ExcelFileUpload.HasFile == false)//HasFile用来检查FileUpload是否有文件
         {
          Response.Write("<script>alert('请您选择Excel文件')</script> ");
          return;//当无文件时,返回
         }
         string IsXls = Path.GetExtension(ExcelFileUpload.FileName).ToString().ToLower();//System.IO.Path.GetExtension获得文件的扩展名
         if (IsXls != ".xlsx" && IsXls != ".xls")
         {
          Response.Write(ExcelFileUpload.FileName);
          Response.Write("<script>alert('只可以选择Excel文件')</script>");
          return;//当选择的不是Excel文件时,返回
         }
        
         string filename = ExcelFileUpload.FileName;//获取Execle文件名 
         string savePath = Server.MapPath(("UploadExcel\\") + filename);//Server.MapPath 服务器上的指定虚拟路径相对应的物理文件路径
         //savePath ="D:\vsproject\Projects\exceltestweb\exceltestweb\uploadfiles\test.xls"
         //Response.Write(savePath);
         DataTable ds = new DataTable();
         ExcelFileUpload.SaveAs(savePath);//将文件保存到指定路径
        
         DataTable dt = GetExcelDatatable(savePath);//读取excel数据
         List<RegNumInfo> regList = ConvertDtToInfo(dt);//将datatable转为list
         File.Delete(savePath);//删除文件
        
         Response.Write("<script>alert('上传文件读取数据成功!');</script>");
        }
        /// <summary>
        /// 从excel文件中读取数据
        /// </summary>
        /// <param name="fileUrl">实体文件的存储路径</param>
        /// <returns></returns>
        private static DataTable GetExcelDatatable(string fileUrl)
        {
         //支持.xls和.xlsx,即包括office2010等版本的;HDR=Yes代表第一行是标题,不是数据;
         string cmdText = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + fileUrl + "; Extended Properties=\"Excel 12.0;HDR=Yes\"";
         System.Data.DataTable dt = null;
         //建立连接
         OleDbConnection conn = new OleDbConnection(cmdText);
         try
         {
          //打开连接
          if (conn.State == ConnectionState.Broken || conn.State == ConnectionState.Closed)
          {
           conn.Open();
          }
        
          System.Data.DataTable schemaTable = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);
          string strSql = "select * from [Sheet1$]"; //这里指定表明为Sheet1,如果修改过表单的名称,请使用修改后的名称
          OleDbDataAdapter da = new OleDbDataAdapter(strSql, conn);
          DataSet ds = new DataSet();
          da.Fill(ds);
          dt = ds.Tables[0]; ;
          return dt;
         }
         catch (Exception exc)
         {
          throw exc;
         }
         finally
         {
          conn.Close();
          conn.Dispose();
         }
        }
        /// <summary>
        /// 将datatable转换为list集合
        /// </summary>
        /// <param name="dt">DataTable</param>
        /// <returns></returns>
        private static List<RegNumInfo> ConvertDtToInfo(DataTable dt)
        {
         List<RegNumInfo> list = new List<RegNumInfo>();
         if (dt.Rows.Count > 0)
         {
          foreach (DataRow item in dt.Rows)
          {
           RegNumInfo info = new RegNumInfo();
           info.RegNum = item[0].ToString();
           info.Name = item[1].ToString();
           info.Period = item[2].ToString();
           info.Remark = item[3].ToString();
           list.Add(info);
          }
         }
         return list;
        }
        public class RegNumInfo
        {
         public string RegNum { get; set; }
         public string Name { get; set; }
         public string Period { get; set; }
         public string Remark { get; set; }
        }

        注意:出现“未在本地计算机上注册“microsoft.ACE.oledb.12.0”提供程序” 的报错的解决方案

          1、因为读取excel文件使用的是OleDb,如果服务器没有安装office,需要安装数据访?#39318;?#20214;(AccessDatabaseEngine);

            *适用于office2010的

            Microsoft Access Database Engine 2010 Redistributable

            https://www.microsoft.com/zh-CN/download/details.aspx?id=13255

          2、在IIS应用程序池中,设置“”启用兼容32位应用程序?#20445;?br />

        解决方案具体可参考这篇文章:http://www.09851116.com/article/157457.htm

        总结

        以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

        相关文章

        • 在aspx页面引用html页的写法

          在aspx页面引用html页的写法

          许多页面的底部或头部内容都是一样的,这样的话我们可以直接建立一个html页面将头部或底部的代码放到html页中
          2014-02-02
        • asp.net快速连接access

          asp.net快速连接access

          网上有很多人在问asp.net连接access的问题,作为一个程序?#20445;?#25105;觉得非常有必要分享一下我是怎么快速,简单连接access数据库的。本经验采用HTML代码结合JS模式,直?#26377;?#22312;网页中,非常适合学习新手。
          2015-09-09
        • 微信公众平台开发之语音识别.Net代码解析

          微信公众平台开发之语音识别.Net代码解析

          这篇文章主要为大家详细解析了微信公众平台开发之语音识别.Net代码,?#34892;?#36259;的小伙伴们可以参?#23478;?#19979;
          2016-06-06
        • asp.net xml序列化与反序列化

          asp.net xml序列化与反序列化

          在.NET下有一种技术叫做对象序列化,它可以将对象序列化为二进制文件、XML文件、SOAP文件,这样, 使用经过序列化的流进行传输效?#31034;?#24471;到了大大的提升。
          2008-08-08
        • .net中自定义错误页面的实现升级篇

          .net中自定义错误页面的实现升级篇

          这篇文章主要给大家介绍了关于.net中自定义错误页面实现的相关资?#24076;?#36825;篇文章是之前的升级篇,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
          2018-06-06
        • ASP.NET中ServerPush用法实例分析

          ASP.NET中ServerPush用法实例分析

          这篇文章主要介绍了ASP.NET中ServerPush用法,实例分析了通过ServerPush实现服务器推送功能,需要的朋友可以参考下
          2015-06-06
        • AspNetPager+GridView实现分页的实例代码

          AspNetPager+GridView实现分页的实例代码

          AspNetPager+GridView实现分页的实例代码,需要的朋友可以参?#23478;?#19979;
          2013-03-03
        • ASPNET按钮只执行客户端代码不回送页面实现思路

          ASPNET按钮只执行客户端代码不回送页面实现思路

          有些时候需要实现只执行客户端代码不回送页面,不过很多童鞋们不清楚如何实现呢,还好本文的出现将解决你的困扰,?#34892;?#36259;的朋友可以了解下,或许对你有所帮助
          2013-02-02
        • ASP.NET Ajax?#35835;狣ropDownList实现代码

          ASP.NET Ajax?#35835;狣ropDownList实现代码

          我想大家对Ajax已耳熟能详。自web 2.0概念出现以后,提供更好的用户体验变得越来越重要。那么今天我来讲解一下如何使用ASP.NET Ajax和web service构建无刷新?#35835;狣ropDownList(以下简称为?#35835;狣DL)。完成的效果图
          2008-12-12
        • ADO.Net对oracle数据库操作的实例代码

          ADO.Net对oracle数据库操作的实例代码

          ADO.Net对oracle数据库操作的实例代码,需要的朋友可以参?#23478;?#19979;
          2013-06-06

        最新评论

        2018白小姐一肖中特马
        <sup id="sjju3"><noscript id="sjju3"></noscript></sup>
        <big id="sjju3"></big>

      2. <blockquote id="sjju3"></blockquote>
        <blockquote id="sjju3"></blockquote>

          <td id="sjju3"></td>

          <big id="sjju3"></big>
            <code id="sjju3"><strong id="sjju3"><dl id="sjju3"></dl></strong></code>
          1. <sup id="sjju3"><noscript id="sjju3"></noscript></sup>
            <big id="sjju3"></big>

          2. <blockquote id="sjju3"></blockquote>
            <blockquote id="sjju3"></blockquote>

              <td id="sjju3"></td>

              <big id="sjju3"></big>
                <code id="sjju3"><strong id="sjju3"><dl id="sjju3"></dl></strong></code>
              1. 湖北11选5历史开奖结果查询结果 12期波叔一波中特图库 山东群英会破解软件 体彩p3开机号近十期 福彩江西快三开奖结果查询 海南体彩app官方下载 彩票控新加坡快乐8 北京赛车冠亚和值表 广西11选5开最快开奖 3d购买技巧 任选9场中奖规则 最新福建31选7中奖新规则 精准合数单双中特公式 20选5玩法一共多少注 3d试机号对应码金码