采用OLEDB读取EXCEL文件

添加命名空间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表格的第二行开始。第一行,类似于数据库中的字段名,是不读取的

你可能感兴趣的:(C#,c#文件)