C#操作Excel(读取)

时间:2023-03-09 16:29:13
C#操作Excel(读取)

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

C#操作Excel(读取)C#操作Excel(读取)    /**//// <summary>
C#操作Excel(读取)        /// 返回Excel数据源
C#操作Excel(读取)        /// </summary>
C#操作Excel(读取)        /// <param name="filename">文件路径</param>
C#操作Excel(读取)        /// <returns></returns> 
C#操作Excel(读取)    static public DataSet ExcelToDataSet(string filename)
C#操作Excel(读取)C#操作Excel(读取)    C#操作Excel(读取){
C#操作Excel(读取)        DataSet ds;
C#操作Excel(读取)        string strCon = "Provider=Microsoft.Jet.OLEDB.4.0;" +
C#操作Excel(读取)                        "Extended Properties=Excel 8.0;" +
C#操作Excel(读取)                        "data source=" + filename;
C#操作Excel(读取)        OleDbConnection myConn = new OleDbConnection(strCon);
C#操作Excel(读取)        string strCom = " SELECT * FROM [Sheet1$]";
C#操作Excel(读取)        myConn.Open();
C#操作Excel(读取)        OleDbDataAdapter myCommand = new OleDbDataAdapter(strCom, myConn);
C#操作Excel(读取)        ds = new DataSet();
C#操作Excel(读取)        myCommand.Fill(ds);
C#操作Excel(读取)        myConn.Close();
C#操作Excel(读取)        return ds;
C#操作Excel(读取)    }

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

C#操作Excel(读取)public  class ExcelHelper
C#操作Excel(读取)C#操作Excel(读取)    C#操作Excel(读取){
C#操作Excel(读取)      private Excel._Application excelApp;
C#操作Excel(读取)      private string fileName=string.Empty;
C#操作Excel(读取)      private Excel.WorkbookClass wbclass;
C#操作Excel(读取)      public ExcelHelper(string _filename)
C#操作Excel(读取)C#操作Excel(读取)      C#操作Excel(读取){
C#操作Excel(读取)          excelApp = new Excel.Application();
C#操作Excel(读取)          object   objOpt   =   System.Reflection.Missing.Value;
C#操作Excel(读取)          wbclass = (Excel.WorkbookClass)excelApp.Workbooks.Open(_filename, objOpt, false, objOpt, objOpt, objOpt, true, objOpt, objOpt, true, objOpt, objOpt, objOpt, objOpt, objOpt);
C#操作Excel(读取)      }
C#操作Excel(读取)C#操作Excel(读取)      /**//// <summary>
C#操作Excel(读取)      /// 所有sheet的名称列表
C#操作Excel(读取)      /// </summary>
C#操作Excel(读取)      /// <returns></returns>
C#操作Excel(读取)      public List<string> GetSheetNames()
C#操作Excel(读取)C#操作Excel(读取)      C#操作Excel(读取){
C#操作Excel(读取)          List<string> list = new List<string>();
C#操作Excel(读取)          Excel.Sheets sheets = wbclass.Worksheets;
C#操作Excel(读取)          string sheetNams = string.Empty;
C#操作Excel(读取)          foreach (Excel.Worksheet sheet in sheets)
C#操作Excel(读取)C#操作Excel(读取)          C#操作Excel(读取){
C#操作Excel(读取)            list.Add(sheet.Name);
C#操作Excel(读取)          }
C#操作Excel(读取)          return list;
C#操作Excel(读取)      }
C#操作Excel(读取)      public Excel.Worksheet GetWorksheetByName(string name)
C#操作Excel(读取)C#操作Excel(读取)      C#操作Excel(读取){
C#操作Excel(读取)          Excel.Worksheet sheet=null;
C#操作Excel(读取)          Excel.Sheets sheets= wbclass.Worksheets;
C#操作Excel(读取)          foreach (Excel.Worksheet s in sheets)
C#操作Excel(读取)C#操作Excel(读取)          C#操作Excel(读取){
C#操作Excel(读取)              if (s.Name == name)
C#操作Excel(读取)C#操作Excel(读取)              C#操作Excel(读取){
C#操作Excel(读取)                  sheet = s;
C#操作Excel(读取)                  break;
C#操作Excel(读取)              }
C#操作Excel(读取)          }
C#操作Excel(读取)          return sheet;
C#操作Excel(读取)      }
C#操作Excel(读取)C#操作Excel(读取)      /**//// <summary>
C#操作Excel(读取)      /// 
C#操作Excel(读取)      /// </summary>
C#操作Excel(读取)      /// <param name="sheetName">sheet名称</param>
C#操作Excel(读取)      /// <returns></returns>
C#操作Excel(读取)      public Array GetContent(string sheetName)
C#操作Excel(读取)C#操作Excel(读取)      C#操作Excel(读取){
C#操作Excel(读取)          Excel.Worksheet sheet = GetWorksheetByName(sheetName);
C#操作Excel(读取)          //获取A1 到AM24范围的单元格
C#操作Excel(读取)          Excel.Range rang = sheet.get_Range("A1", "AM24");
C#操作Excel(读取)          //读一个单元格内容
C#操作Excel(读取)          //sheet.get_Range("A1", Type.Missing);
C#操作Excel(读取)        //不为空的区域,列,行数目
C#操作Excel(读取)       //   int l = sheet.UsedRange.Columns.Count;
C#操作Excel(读取)         // int w = sheet.UsedRange.Rows.Count;
C#操作Excel(读取)        //  object[,] dell = sheet.UsedRange.get_Value(Missing.Value) as object[,];
C#操作Excel(读取)          System.Array values = (Array)rang.Cells.Value2;
C#操作Excel(读取)          return values;
C#操作Excel(读取)      }
C#操作Excel(读取)
C#操作Excel(读取)      public void Close()
C#操作Excel(读取)C#操作Excel(读取)      C#操作Excel(读取){
C#操作Excel(读取)          excelApp.Quit();
C#操作Excel(读取)          excelApp = null;
C#操作Excel(读取)      }
C#操作Excel(读取)   
C#操作Excel(读取)    }