C#操作Excel(读取)

本文介绍了两种从Excel读取数据的方法:一种是使用OleDb,另一种是通过COM组件Microsoft Excel。详细展示了如何利用这些方法获取Excel中的数据及工作表名称。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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


/**////
<summary>
       
/// 返回Excel数据源
       
///
</summary>
       
///
<param name="filename">文件路径</param>
       
///
<returns></returns>


static
public DataSet ExcelToDataSet(string filename)
   
{
        DataSet ds;
       
string strCon =
"Provider=Microsoft.Jet.OLEDB.4.0;"
+
                       
"Extended Properties=Excel 8.0;"
+
                       
"data source="
+ filename;
        OleDbConnection myConn
=
new OleDbConnection(strCon);
       
string strCom =
" SELECT * FROM [Sheet1$]";
        myConn.Open();
        OleDbDataAdapter myCommand
=
new OleDbDataAdapter(strCom, myConn);
        ds
=
new DataSet();
        myCommand.Fill(ds);
        myConn.Close();
       
return ds;
    }


二.使用com.
导入Microsoft.Excel
使用命名空间
using Excel= Microsoft.Office.Interop.Excel;
using System.Diagnostics;
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;
      }

 
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值