服务器上传excel文件并读取数据,【asp.net】asp.net实现上传Excel文件并读取数据

正文

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

2         

3             

4             

5         

6     

#服务端代码:

AAffA0nNPuCLAAAAAElFTkSuQmCC1 protected void UploadBtn_Click(object sender, EventArgs e)  

2 {

3     if (ExcelFileUpload.HasFile == false)//HasFile用来检查FileUpload是否有文件

4     {

5         Response.Write("alert('请您选择Excel文件') ");

6         return;//当无文件时,返回

7     }

8     string IsXls = Path.GetExtension(ExcelFileUpload.FileName).ToString().ToLower();//System.IO.Path.GetExtension获得文件的扩展名

9     if (IsXls != ".xlsx" && IsXls != ".xls")

10     {

11         Response.Write(ExcelFileUpload.FileName);

12         Response.Write("alert('只可以选择Excel文件')");

13         return;//当选择的不是Excel文件时,返回

14     }

15

16     string filename = ExcelFileUpload.FileName;//获取Execle文件名

17     string savePath = Server.MapPath(("UploadExcel\\") + filename);//Server.MapPath 服务器上的指定虚拟路径相对应的物理文件路径

18     //savePath ="D:\vsproject\Projects\exceltestweb\exceltestweb\uploadfiles\test.xls"

19     //Response.Write(savePath);

20     DataTable ds = new DataTable();

21     ExcelFileUpload.SaveAs(savePath);//将文件保存到指定路径

22

23     DataTable dt = GetExcelDatatable(savePath);//读取excel数据

24     List regList = ConvertDtToInfo(dt);//将datatable转为list

25     File.Delete(savePath);//删除文件

26

27     Response.Write("alert('上传文件读取数据成功!');");

28 }

29 /// 

30 /// 从excel文件中读取数据

31 /// 

32 /// 实体文件的存储路径

33 /// 

34 private static DataTable GetExcelDatatable(string fileUrl)

35 {

36     //支持.xls和.xlsx,即包括office2010等版本的;HDR=Yes代表第一行是标题,不是数据;

37     string cmdText = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + fileUrl + "; Extended Properties=\"Excel 12.0;HDR=Yes\"";

38     System.Data.DataTable dt = null;

39     //建立连接

40     OleDbConnection conn = new OleDbConnection(cmdText);

41     try

42     {

43         //打开连接

44         if (conn.State == ConnectionState.Broken || conn.State == ConnectionState.Closed)

45         {

46             conn.Open();

47         }

48

49         System.Data.DataTable schemaTable = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null);

50         string strSql = "select * from [Sheet1$]";   //这里指定表明为Sheet1,如果修改过表单的名称,请使用修改后的名称

51         OleDbDataAdapter da = new OleDbDataAdapter(strSql, conn);

52         DataSet ds = new DataSet();

53         da.Fill(ds);

54         dt = ds.Tables[0]; ;

55         return dt; 56     }

57     catch (Exception exc)

58     {

59         throw exc;

60     }

61     finally

62     {

63         conn.Close();

64         conn.Dispose();

65     }

66 }

67 ///  68 /// 将datatable转换为list集合

69 /// 

70 /// DataTable

71 /// 

72 private static List ConvertDtToInfo(DataTable dt)

73 {

74     List list = new List();

75     if (dt.Rows.Count > 0)

76     {

77         foreach (DataRow item in dt.Rows)

78         {

79             RegNumInfo info = new RegNumInfo();

80             info.RegNum = item[0].ToString();

81             info.Name = item[1].ToString();

82             info.Period = item[2].ToString();

83             info.Remark = item[3].ToString();

84             list.Add(info);

85         }

86     }

87     return list;

88 }

AAffA0nNPuCLAAAAAElFTkSuQmCC

AAffA0nNPuCLAAAAAElFTkSuQmCC1 public class RegNumInfo 

2 {

3     public string RegNum { get; set; }

4     public string Name { get; set; }

5     public string Period { get; set; }

6     public string Remark { get; set; }

7 }

AAffA0nNPuCLAAAAAElFTkSuQmCC

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

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

*适用于office2010的

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

#参考:

https://blog.csdn.net/eagle_or_snail/article/details/82748226

https://www.cnblogs.com/willingtolove/p/9630485.html

作者:willingtolove

出处:http://www.cnblogs.com/willingtolove/

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

参与评论 您还未登录,请先 登录 后发表或查看评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:1024 设计师:我叫白小胖 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值