#前台代碼:使用服務端控件實現上傳
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