調用頁面:api
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; using JuMi.BLL.Business; using System.Data; using System.Data.OleDb; using System.Windows.Forms; using JuMi.Model.Business; using JuMi.BLL.Business; namespace JuMi.Web.Form.Manager.Business { public partial class WebForm1 : JuMi.Web.UI.BasePage { protected void Page_Load(object sender, EventArgs e) { } /// <summary> /// 導入廣告商信息 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> protected void btnAdverInfo_Click(object sender, EventArgs e) { DataTable dt = ExcelDemo.GetExcelToDatatable("F:\\Demo\\excelDemo.xlsx", "table"); int count = 0; for (int i = 0; i < dt.Rows.Count; i++) { Model_Advertiser model = new Model_Advertiser(); model.Adver_CompanyName = dt.Rows[i][0].ToString();//名稱 model.Adver_Distinguish = dt.Rows[i][1].ToString();//稅號 model.Adver_RegisPhone = dt.Rows[i][2].ToString();//電話 model.Adver_BankNumber = dt.Rows[i][3].ToString();//銀行帳號 model.Adver_BankAddress = dt.Rows[i][4].ToString();//開戶行地址 model.Adver_RegisAdress = dt.Rows[i][5].ToString();//註冊地址 model.Adver_State = 0; if (AdvertiserBLL.Add(model) > 0) { count++; } } if (count >= dt.Rows.Count) { JscriptMsgSuccess("廣告商信息導入成功!", "", "function(){api.reload();}"); } else { JscriptMsgError("廣告商信息導入失敗!", "", "function(){api.reload();}"); } } } }
實現方法頁:ide
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data; using System.Data.OleDb; namespace JuMi.BLL.Business { public class ExcelDemo { /// <summary> /// Excel數據導入Datable /// </summary> /// <param name="fileUrl">文件路徑</param> /// <param name="table"></param> /// <returns></returns> public static DataTable GetExcelToDatatable(string fileUrl, string table) { //支持office2007以前的 .xls //const string cmdText = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source={0};Extended Properties='Excel 8.0;IMEX=1';";//連接字符串 //支持.xls和.xlsx,即包括office2010等版本的 HDR=Yes表明第一行是標題,不是數據; const string cmdText = "Provider=Microsoft.Ace.OleDb.12.0;Data Source={0};Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'"; DataTable dt = null; //創建鏈接 OleDbConnection conn = new OleDbConnection(string.Format(cmdText, fileUrl)); try { //打開連接 if (conn.State == ConnectionState.Broken || conn.State == ConnectionState.Closed) { conn.Open(); } DataTable schemaTable = conn.GetOleDbSchemaTable(OleDbSchemaGuid.Tables, null); //獲取excel的第一個sheet名稱 string sheetName1 = schemaTable.Rows[0]["TABLE_NAME"].ToString().Trim(); //查詢sheet數據 string strSql1 = "select * from [" + sheetName1 + "]"; OleDbDataAdapter da = new OleDbDataAdapter(strSql1, conn); DataSet ds = new DataSet(); da.Fill(ds, table); dt = ds.Tables["" + table + ""]; return dt; } catch (Exception exc) { throw exc; } finally { conn.Close(); conn.Dispose(); } } } }