C#操作Excel(读取)

一.使用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;
      }

   
    }

其他链接:
创建、打开、读取、写入、保存的一般性代码
告别ASP.NET操作EXCEL的烦恼(总结篇)
Tag标签: C#读取Excel

posted on 2008-04-14 14:59 Solog 阅读(271) 评论(0)  编辑 收藏 所属分类: .NET相关


标题  
姓名  
主页
Email (博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
博客园首页

新闻频道

社区

小组

博问

网摘

闪存

  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2008-04-14 15:17 编辑过
成果网帮您增加网站收入


相关链接:
 

导航

公告


MSN:solog(at)live.com

QQ:89208242
<2008年4月>
303112345
6789101112
13141516171819
20212223242526
27282930123
45678910

统计

与我联系

搜索

 

常用链接

留言簿(5)

我参加的小组

我参与的团队

我的标签

随笔分类

随笔档案

文章分类

相册

收藏夹

Links

solo's Friend's

其它小巢

最新随笔

最新评论

  • 1. re: 飞信机器人FXRobot
  •   能不能提供下你的QQ啊,直接和你QQ请教啊,谢谢了!
  • --feixin
  • 2. re: 飞信机器人FXRobot
  • 为什么我的也不行?我把你提供下载的文件复制进去后就不能运行飞信了啊?我也是用的2008的啊.把你的包下载后我解压之后该怎么做?我是按你说的把他复制到飞信客户端路径里面去,之后就不能运行啊.
  • --feixin
  • 3. re: 飞信机器人FXRobot
  • 备份X:\Program Files\China Mobile\Fetion 下面的FetionFx.exe. 把fxrobot_compile_dll.rar里的文件Copy进去.OK了。 PS:...
  • --Solog
  • 4. re: 飞信机器人FXRobot
  • 我复制进去 不行呢?
  • --zp
  • 5. re: Installshield12 创建自定义Web站点
  • 据我知道is在创建站点时,必须下面要创建虚拟目录才能正常创建站点,我的问题是:如果我只创建一个站点,不需要虚拟目录,也就是站点根目录就是我要创建的虚拟目录,这时应该如何配置?
    谢谢。。
  • --nectx

阅读排行榜

评论排行榜