• 习近平总书记重要讲话在内蒙古各界引发热烈反响 2019-05-22
  • 女性之声——全国妇联 2019-05-21
  • 新华时评:美逆潮流而动,必将付出代价 2019-05-21
  • 好朋友、和平奖可能人家抱了。 2019-05-20
  • 【北京荣祥月达车型报价】北京荣祥月达综合店车型价格 2019-05-20
  • 脸上长痘代表对应内脏有问题?专家:未发现相关性 2019-05-19
  • 和静县首届东归节6月23日开幕 2019-05-18
  • 太空监视飞行器相关新闻 2019-05-18
  • 警车化身“产房” 冰雪路上“生命接力” 2019-05-17
  • 百部网络正能量动漫音视频作品评选 2019-05-16
  • 初二少年与家长争吵离家出走 客运站人员发觉异样后拦下 2019-05-15
  • 陈海滢的专栏作者中国国家地理网 2019-05-14
  • 乐平市:开展流动党校“培训在基层”活动(图) 2019-05-13
  • 你遇到了吗用户吐槽升iOS 11.4后耗电过快用户吐槽升iOS11后耗电过快-行情资讯 2019-05-12
  • 兼容海量游戏外设 微软打碟机竟是万用控制器 2019-05-12
  • 香港赛马会内部6码:asp.net上传Excel文件并读取数据的实现方法

    香港赛马会网站惠泽社绝杀八码 www.mwcrz.tw  更新时间:2019年03月07日 09:47:29   作者:willingtolove   我要评论

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

    前言

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

    实现如下:

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

      <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,需要安装数据访问组件(AccessDatabaseEngine);

        *适用于office2010的

        Microsoft Access Database Engine 2010 Redistributable

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

      2、在IIS应用程序池中,设置“”启用兼容32位应用程序”;

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

    总结

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

    相关文章

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

      在aspx页面引用html页的写法

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

      asp.net快速连接access

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

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

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

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

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

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

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

      ASP.NET中ServerPush用法实例分析

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

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

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

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

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

      ASP.NET Ajax级联DropDownList实现代码

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

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

      ADO.Net对oracle数据库操作的实例代码,需要的朋友可以参考一下
      2013-06-06

    最新评论

  • 习近平总书记重要讲话在内蒙古各界引发热烈反响 2019-05-22
  • 女性之声——全国妇联 2019-05-21
  • 新华时评:美逆潮流而动,必将付出代价 2019-05-21
  • 好朋友、和平奖可能人家抱了。 2019-05-20
  • 【北京荣祥月达车型报价】北京荣祥月达综合店车型价格 2019-05-20
  • 脸上长痘代表对应内脏有问题?专家:未发现相关性 2019-05-19
  • 和静县首届东归节6月23日开幕 2019-05-18
  • 太空监视飞行器相关新闻 2019-05-18
  • 警车化身“产房” 冰雪路上“生命接力” 2019-05-17
  • 百部网络正能量动漫音视频作品评选 2019-05-16
  • 初二少年与家长争吵离家出走 客运站人员发觉异样后拦下 2019-05-15
  • 陈海滢的专栏作者中国国家地理网 2019-05-14
  • 乐平市:开展流动党校“培训在基层”活动(图) 2019-05-13
  • 你遇到了吗用户吐槽升iOS 11.4后耗电过快用户吐槽升iOS11后耗电过快-行情资讯 2019-05-12
  • 兼容海量游戏外设 微软打碟机竟是万用控制器 2019-05-12