WinForm讀取Excel檔案

zhang98722發表於2011-05-06

這兩天做東西,用到了Excel。需要將Excel中的資料讀取到記憶體中,經過處理後,儲存到資料庫中。在網上找了好多方法,但都有錯誤。現總結下:

1.引用Microsoft.Office.Interop.Excel

2.程式碼:

 

  1. /// <summary>  
  2.         /// 匯入Excel檔案,並顯示在列表  
  3.         /// </summary>  
  4.         /// <param name="sender"></param>  
  5.         /// <param name="e"></param>  
  6.         private void btnImport_Click(object sender, EventArgs e)  
  7.         {  
  8.             string worksheetname = string.Empty;  
  9.             importtpye = cmbTicketType.Text;  
  10.             supplier = cmbSupplier.SelectedValue.ToString();  
  11.  
  12.             #region 匯入本地Excel檔案  
  13.  
  14.             //匯入本地檔案  
  15.             OpenFileDialog file = new OpenFileDialog();  
  16.             file.Filter = "文件(*.xls)|*.xls";  
  17.             if (file.ShowDialog() == DialogResult.OK)  
  18.                 btnImport.Tag = file.FileName;  
  19.             //判斷有沒有檔案匯入  
  20.             if (file.FileName.Length == 0)  
  21.             {  
  22.                 MessageBox.Show("請選擇要匯入的檔案""提示", MessageBoxButtons.OK, MessageBoxIcon.Information);  
  23.                 return;  
  24.             }  
  25.  
  26.             #endregion  
  27.  
  28.             #region 獲取Excel的工作表名稱  
  29.             //建立Excel例項,獲取worksheet Name  
  30.             Microsoft.Office.Interop.Excel.Application oExcel = new Microsoft.Office.Interop.Excel.Application();  
  31.             object objMissing = System.Reflection.Missing.Value;  
  32.             Microsoft.Office.Interop.Excel.Workbook myBook = (Microsoft.Office.Interop.Excel.Workbook)oExcel.Workbooks.Open(file.FileName, objMissing, objMissing, objMissing, objMissing, objMissing, objMissing, objMissing, objMissing, objMissing, objMissing, objMissing, objMissing, objMissing, objMissing);  
  33.             Microsoft.Office.Interop.Excel.Sheets sheets = myBook.Worksheets;  
  34.             Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)sheets.get_Item(1);  
  35.             worksheetname = worksheet.Name;//獲取worksheet Name  
  36.             oExcel.Quit();  
  37.             #endregion   
  38.  
  39.             dataTable.Rows.Clear();  
  40.             //將Excel表中的資料匯入到Datatable中  
  41.             DataTable table = LoadExcelToDataTable(file.FileName, worksheetname);  
  42.               
  43.         }  

3.程式碼:

 

  1. /// <summary>  
  2.        /// 載入Excel表到DataTable,跟原始Excel表形式一樣,需要篩選自己有用的資料  
  3.        /// </summary>  
  4.        /// <param name="filename">需要讀取的Excel檔案路徑</param>  
  5.        /// <param name="sheetname">工作表名稱</param>  
  6.        /// <returns>DataTable</returns>  
  7.        public static DataTable LoadExcelToDataTable(string filename, string worksheetname)  
  8.        {   
  9.            DataTable table;  
  10.            //連線字串  
  11.            String sConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + filename + ";" + "Extended Properties=/"Excel 8.0;HDR=Yes;IMEX=1/"";  
  12.            OleDbConnection myConn = new OleDbConnection(sConnectionString);  
  13.            string strCom = " SELECT * FROM [" + worksheetname + "$]";  
  14.            myConn.Open();  
  15.            OleDbDataAdapter myCommand = new OleDbDataAdapter(strCom, myConn);  
  16.            table = new DataTable();  
  17.            myCommand.Fill(table);  
  18.            myConn.Close();  
  19.            return table;  
  20.        } 

4.注意:有的人的連線字串寫成這樣:

  1. //連線字串  
  2.             String sConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" +   
  3.  
  4. filename + ";" + "Extended Properties=Excel 8.0;"

這樣也可以讀取到資料,但是,如果Excel表裡的某一列中既有文字型別的值,又有數字型別的值,即混合型別的列,那麼就會只讀取到一種型別的值,另一種型別的就會為NULL。

  1. //連線字串  
  2.             String sConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + filename + ";" + "Extended Properties=/"Excel 8.0;HDR=Yes;IMEX=1/""

這樣,後邊加上"HDR=Yse;IMEX=1",並且這句必須用引號引住,這樣就會把混合型別的資料同一當作文字讀取,不會出現丟資料的現象。

本文出自 “小狼” 部落格,請務必保留此出處http://canyan3073.blog.51cto.com/1576306/383374

相關文章