使用OLEDB操作Excel

1、OLEDB介绍

https://www.cnblogs.com/moss_tan_jun/archive/2012/07/28/2612889.html

2、连接字符串

老版本

"Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + fileName + ";" + ";Extended Properties=\"Excel 8.0;HDR=YES;IMEX=1\"";

新版本

"Provider=Microsoft.ACE.OLEDB.12.0;" + "Data Source=" + fileName + ";" + ";Extended Properties=\"Excel 12.0;HDR=YES;IMEX=1\"";
3、Excel操作

在这里插入图片描述
脚本示例:

using System;
using System.Data;
using System.Data.OleDb;
/*
* Json操作
* 2020/4/15
* 引用System.Data.OleDb、System.Data
*/
namespace Excel操作
{
    class Program
    {
        static void Main(string[] args)
        {
            string fileName = "装备信息.xls";
            string connectionString = "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source="
                + fileName + ";" + ";Extended Properties=\"Excel 8.0;HDR=YES;IMEX=1\"";
            //创建连接到数据源的对象
            OleDbConnection connerction = new OleDbConnection(connectionString);

            //打开连接
            connerction.Open();
            string sql = "select*from[Sheet1$";   //这是一个查询命令
            OleDbDataAdapter adapter = new OleDbDataAdapter(sql,connerction);
            //用来存放数据,用来存放DataTable
            DataSet dataSet = new DataSet();
            //表示把查询的结果(datatable)放到(填充)dataset里面
            adapter.Fill(dataSet);
            connerction.Close();   //关闭连接

            //取得数据
            DataTableCollection tableCollection = dataSet.Tables;   //获取当前集合中所有的表格
            //因为我们只往dataSet里面放置了一张表格,所以这里取得索引为0的表格就是我们刚刚查询到的表格
            DataTable table = tableCollection[0];

            //取得表格中数据
            //取得table中所有的行
            DataRowCollection rowCollection = table.Rows;   //返回了一个行的集合
            foreach(DataRow row in rowCollection)
            {
                //取得row中前8列的数据 索引0-7
                for(int i = 0; i < 8; i++)
                {
                    Console.Write(row[i] + "");
                }
            }
            Console.ReadKey();
        }
    }
}
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值