一.使用OleDb,这个法子好像不大好使.容易读错.
引用System.Data.OleDb;

C#操作Excel(读取)_文件路径C#操作Excel(读取)_microsoft_02    /**//// <summary>
C#操作Excel(读取)_文件路径_03        
/// 返回Excel数据源
C#操作Excel(读取)_文件路径_03        
/// </summary>
C#操作Excel(读取)_文件路径_03        
/// <param name="filename">文件路径</param>
C#操作Excel(读取)_命名空间_06        
/// <returns></returns> 

C#操作Excel(读取)_文件路径_07    static public DataSet ExcelToDataSet(string filename)
C#操作Excel(读取)_文件路径C#操作Excel(读取)_microsoft_02    
C#操作Excel(读取)_microsoft_10{
C#操作Excel(读取)_文件路径_03        DataSet ds;
C#操作Excel(读取)_文件路径_03        
string strCon = "Provider=Microsoft.Jet.OLEDB.4.0;" +
C#操作Excel(读取)_文件路径_03                        
"Extended Properties=Excel 8.0;" +
C#操作Excel(读取)_文件路径_03                        
"data source=" + filename;
C#操作Excel(读取)_文件路径_03        OleDbConnection myConn 
= new OleDbConnection(strCon);
C#操作Excel(读取)_文件路径_03        
string strCom = " SELECT * FROM [Sheet1$]";
C#操作Excel(读取)_文件路径_03        myConn.Open();
C#操作Excel(读取)_文件路径_03        OleDbDataAdapter myCommand 
= new OleDbDataAdapter(strCom, myConn);
C#操作Excel(读取)_文件路径_03        ds 
= new DataSet();
C#操作Excel(读取)_文件路径_03        myCommand.Fill(ds);
C#操作Excel(读取)_文件路径_03        myConn.Close();
C#操作Excel(读取)_文件路径_03        
return ds;
C#操作Excel(读取)_命名空间_06    }


二.使用com.
导入Microsoft.Excel
使用命名空间
using Excel= Microsoft.Office.Interop.Excel;
using System.Diagnostics;

C#操作Excel(读取)_文件路径_07public  class ExcelHelper
C#操作Excel(读取)_文件路径C#操作Excel(读取)_microsoft_02    
C#操作Excel(读取)_microsoft_10{
C#操作Excel(读取)_文件路径_03      
private Excel._Application excelApp;
C#操作Excel(读取)_文件路径_03      
private string fileName=string.Empty;
C#操作Excel(读取)_文件路径_03      
private Excel.WorkbookClass wbclass;
C#操作Excel(读取)_文件路径_03      
public ExcelHelper(string _filename)
C#操作Excel(读取)_数据源_32C#操作Excel(读取)_数据源_33      
C#操作Excel(读取)_microsoft_10{
C#操作Excel(读取)_文件路径_03          excelApp 
= new Excel.Application();
C#操作Excel(读取)_文件路径_03          
object   objOpt   =   System.Reflection.Missing.Value;
C#操作Excel(读取)_文件路径_03          wbclass 
= (Excel.WorkbookClass)excelApp.Workbooks.Open(_filename, objOpt, false, objOpt, objOpt, objOpt, true, objOpt, objOpt, true, objOpt, objOpt, objOpt, objOpt, objOpt);
C#操作Excel(读取)_microsoft_38      }

C#操作Excel(读取)_数据源_32C#操作Excel(读取)_数据源_33      
/**//// <summary>
C#操作Excel(读取)_文件路径_03      
/// 所有sheet的名称列表
C#操作Excel(读取)_文件路径_03      
/// </summary>
C#操作Excel(读取)_microsoft_38      
/// <returns></returns>

C#操作Excel(读取)_文件路径_03      public List<string> GetSheetNames()
C#操作Excel(读取)_数据源_32C#操作Excel(读取)_数据源_33      
C#操作Excel(读取)_microsoft_10{
C#操作Excel(读取)_文件路径_03          List
<string> list = new List<string>();
C#操作Excel(读取)_文件路径_03          Excel.Sheets sheets 
= wbclass.Worksheets;
C#操作Excel(读取)_文件路径_03          
string sheetNams = string.Empty;
C#操作Excel(读取)_文件路径_03          
foreach (Excel.Worksheet sheet in sheets)
C#操作Excel(读取)_数据源_32C#操作Excel(读取)_数据源_33          
C#操作Excel(读取)_microsoft_10{
C#操作Excel(读取)_文件路径_03            list.Add(sheet.Name);
C#操作Excel(读取)_microsoft_38          }

C#操作Excel(读取)_文件路径_03          
return list;
C#操作Excel(读取)_microsoft_38      }

C#操作Excel(读取)_文件路径_03      
public Excel.Worksheet GetWorksheetByName(string name)
C#操作Excel(读取)_数据源_32C#操作Excel(读取)_数据源_33      
C#操作Excel(读取)_microsoft_10{
C#操作Excel(读取)_文件路径_03          Excel.Worksheet sheet
=null;
C#操作Excel(读取)_文件路径_03          Excel.Sheets sheets
= wbclass.Worksheets;
C#操作Excel(读取)_文件路径_03          
foreach (Excel.Worksheet s in sheets)
C#操作Excel(读取)_数据源_32C#操作Excel(读取)_数据源_33          
C#操作Excel(读取)_microsoft_10{
C#操作Excel(读取)_文件路径_03              
if (s.Name == name)
C#操作Excel(读取)_数据源_32C#操作Excel(读取)_数据源_33              
C#操作Excel(读取)_microsoft_10{
C#操作Excel(读取)_文件路径_03                  sheet 
= s;
C#操作Excel(读取)_文件路径_03                  
break;
C#操作Excel(读取)_microsoft_38              }

C#操作Excel(读取)_microsoft_38          }

C#操作Excel(读取)_文件路径_03          
return sheet;
C#操作Excel(读取)_microsoft_38      }

C#操作Excel(读取)_数据源_32C#操作Excel(读取)_数据源_33      
/**//// <summary>
C#操作Excel(读取)_文件路径_03      
/// 
C#操作Excel(读取)_文件路径_03      
/// </summary>
C#操作Excel(读取)_文件路径_03      
/// <param name="sheetName">sheet名称</param>
C#操作Excel(读取)_microsoft_38      
/// <returns></returns>

C#操作Excel(读取)_文件路径_03      public Array GetContent(string sheetName)
C#操作Excel(读取)_数据源_32C#操作Excel(读取)_数据源_33      
C#操作Excel(读取)_microsoft_10{
C#操作Excel(读取)_文件路径_03          Excel.Worksheet sheet 
= GetWorksheetByName(sheetName);
C#操作Excel(读取)_文件路径_03          
//获取A1 到AM24范围的单元格
C#操作Excel(读取)_文件路径_03
          Excel.Range rang = sheet.get_Range("A1""AM24");
C#操作Excel(读取)_文件路径_03          
//读一个单元格内容
C#操作Excel(读取)_文件路径_03          
//sheet.get_Range("A1", Type.Missing);
C#操作Excel(读取)_文件路径_03        
//不为空的区域,列,行数目
C#操作Excel(读取)_文件路径_03       
//   int l = sheet.UsedRange.Columns.Count;
C#操作Excel(读取)_文件路径_03         
// int w = sheet.UsedRange.Rows.Count;
C#操作Excel(读取)_文件路径_03        
//  object[,] dell = sheet.UsedRange.get_Value(Missing.Value) as object[,];
C#操作Excel(读取)_文件路径_03
          System.Array values = (Array)rang.Cells.Value2;
C#操作Excel(读取)_文件路径_03          
return values;
C#操作Excel(读取)_microsoft_38      }

C#操作Excel(读取)_文件路径_03
C#操作Excel(读取)_文件路径_03      
public void Close()
C#操作Excel(读取)_数据源_32C#操作Excel(读取)_数据源_33      
C#操作Excel(读取)_microsoft_10{
C#操作Excel(读取)_文件路径_03          excelApp.Quit();
C#操作Excel(读取)_文件路径_03          excelApp 
= null;
C#操作Excel(读取)_microsoft_38      }

C#操作Excel(读取)_文件路径_03   
C#操作Excel(读取)_命名空间_06    }