采用OLEDB读取EXCEL文件

2 篇文章 0 订阅

添加命名空间usingSystem.Data.OleDb;//Excel表数据操作

//选择文件

 private void simpleButton1_Click(object sender, EventArgs e)
        {
            textEdit1.Text = SelectPath();
        }

        private string SelectPath()
        {
            string path = string.Empty;
            var openFileDialog = new Microsoft.Win32.OpenFileDialog()
            {
                Filter = "Files (*.xls)|*.xls|(*.xlsx)|*.xlsx"//如果需要筛选txt文件("Files (*.txt)|*.txt")
                //Filter = "Files (全部文件)|*.*"
            };
            var result = openFileDialog.ShowDialog();
            if (result == true)
            {
                path = openFileDialog.FileName;
            }
            return path;
        }

//读取Excel文件

 public static DataTable ReadExcel(string filePath)
        {
            try
            {
                //创建连接,引用协议
                string strConn;
                //strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filePath + ";Extended Properties='Excel8.0;HDR=False;IMEX=1'";
                strConn = "Provider=Microsoft.ACE.OLEDB.12.0;Data source=" + filePath + ";Extended Properties='Excel 12.0; HDR=NO;IMEX=1'";//此连接可以操作.xls与.xlsx文件
                OleDbConnection OleConn=new OleDbConnection(strConn); 
                OleConn.Open();
                String sql = "SELECT* FROM[Sheet1$]";//可是更改Sheet名称,比如sheet2,等等 
                OleDbDataAdapter OleDaExcel=new OleDbDataAdapter(sql,OleConn);
                DataSet OleDsExcle=new DataSet();
                OleDaExcel.Fill(OleDsExcle,"Sheet1");
                OleConn.Close(); 
                return OleDsExcle.Tables["Sheet1"];
            }
            catch(Exception err)
            {
                MessageBox.Show("数据绑定Excel失败!失败原因:"+err.Message,"提示信息", MessageBoxButtons.OK, MessageBoxIcon.Information);
                return null;
            }
        }
 DataTable dt = ReadExcel(textEdit1.Text); ;//存放Excel表的内容到DataTable中

以上代码实现了Excel的读取,并把内容存放在dataset中.接着,讲解下如何应用该datatable。

方式一:把datatable内容读取到DataGridView中,显示所有Excel内容。1.先添加DataGridView控件,并命名为dataGridView12.添加DataGridView数据绑定语句如下:DataTabledt;//存放Excel表的内容dt=ReadExcel(“E://1.xls”);//这里的路径,指的是你Excel表格存放的路径dataGridView1.DataSource=dt;

方式二:1.添加一个label标签,命名为label12.添加语句; label1.Text=dt.Rows[x][y].ToString(); //这里的参数x,y,对应的是你Excel表格的单元格内容。注意下,x,y是从0开始取值。 最后还有一点要说明,就是读取的内容是从Excel表格的第二行开始。第一行,类似于数据库中的字段名,是不读取的

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值