【asp.net】asp.net實現上傳Excel文件並讀取數據


#前台代碼:使用服務端控件實現上傳

1     <form id="form1" runat="server">
2         <div>
3             <asp:FileUpload ID="ExcelFileUpload" runat="server" />
4             <asp:Button ID="UploadBtn" runat="server" Text="確定上傳" OnClick="UploadBtn_Click" />
5         </div>
6     </form>

 #服務端代碼:

 1 protected void UploadBtn_Click(object sender, EventArgs e)
 2 {
 3     if (ExcelFileUpload.HasFile == false)//HasFile用來檢查FileUpload是否有文件
 4     {
 5         Response.Write("<script>alert('請您選擇Excel文件')</script> ");
 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("<script>alert('只可以選擇Excel文件')</script>");
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<RegNumInfo> regList = ConvertDtToInfo(dt);//將datatable轉為list
25     File.Delete(savePath);//刪除文件
26 
27     Response.Write("<script>alert('上傳文件讀取數據成功!');</script>");
28 }
29 /// <summary>
30 /// 從excel文件中讀取數據
31 /// </summary>
32 /// <param name="fileUrl">實體文件的存儲路徑</param>
33 /// <returns></returns>
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 /// <summary>
68 /// 將datatable轉換為list集合
69 /// </summary>
70 /// <param name="dt">DataTable</param>
71 /// <returns></returns>
72 private static List<RegNumInfo> ConvertDtToInfo(DataTable dt)
73 {
74     List<RegNumInfo> list = new List<RegNumInfo>();
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 }

 

1 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 }

 

#注意:出現“未在本地計算機上注冊“microsoft.ACE.oledb.12.0”提供程序” 的報錯的解決方案

  1、因為讀取excel文件使用的是OleDb,如果服務器沒有安裝office,需要安裝數據訪問組件(AccessDatabaseEngine);

    *適用於office2010的

    Microsoft Access Database Engine 2010 Redistributable

  2、在IIS應用程序池中,設置“”啟用兼容32位應用程序”;

解決方案具體可參考這篇文章:https://www.cnblogs.com/willingtolove/p/9630485.html

 

#參考:

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

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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM