WinForm讀取Excel文件

這兩天做東西,用到了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",並且這句必須用引號引住,這樣就會把混合類型的數據同一當作文本讀取,不會出現丟數據的現象。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章