
public class ExcelHelper


{

private Excel._Application excelApp;

private string fileName=string.Empty;

private Excel.WorkbookClass wbclass;

public ExcelHelper(string _filename)


{

excelApp = new Excel.Application();

object objOpt = System.Reflection.Missing.Value;

wbclass = (Excel.WorkbookClass)excelApp.Workbooks.Open(_filename, objOpt, false, objOpt, objOpt, objOpt, true, objOpt, objOpt, true, objOpt, objOpt, objOpt, objOpt, objOpt);

}


/**//// <summary>

/// 所有sheet的名称列表

/// </summary>

/// <returns></returns>

public List<string> GetSheetNames()


{

List<string> list = new List<string>();

Excel.Sheets sheets = wbclass.Worksheets;

string sheetNams = string.Empty;

foreach (Excel.Worksheet sheet in sheets)


{

list.Add(sheet.Name);

}

return list;

}

public Excel.Worksheet GetWorksheetByName(string name)


{

Excel.Worksheet sheet=null;

Excel.Sheets sheets= wbclass.Worksheets;

foreach (Excel.Worksheet s in sheets)


{

if (s.Name == name)


{

sheet = s;

break;

}

}

return sheet;

}


/**//// <summary>

///

/// </summary>

/// <param name="sheetName">sheet名称</param>

/// <returns></returns>

public Array GetContent(string sheetName)


{

Excel.Worksheet sheet = GetWorksheetByName(sheetName);

//获取A1 到AM24范围的单元格

Excel.Range rang = sheet.get_Range("A1", "AM24");

//读一个单元格内容

//sheet.get_Range("A1", Type.Missing);

//不为空的区域,列,行数目

// int l = sheet.UsedRange.Columns.Count;

// int w = sheet.UsedRange.Rows.Count;

// object[,] dell = sheet.UsedRange.get_Value(Missing.Value) as object[,];

System.Array values = (Array)rang.Cells.Value2;

return values;

}

public void Close()


{

excelApp.Quit();

excelApp = null;

}

}
转载自:http://www.cnblogs.com/solo/archive/2008/04/14/1152802.html