将简单Excel表格显示到DataGridView中

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Data.OleDb;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace DataGridView添加Excel数据
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        private void Form1_Load(object sender, EventArgs e)
        {

        }
        //清理解决方案是把编译器编译出来的文件都清理掉包括可执行的文件链接库


        public DataSet getData()
        {
            //打开文件
            OpenFileDialog file = new OpenFileDialog();
            file.Filter = "Excel(*.xlsx)|*.xlsx|Excel(*.xls)|*.xls";
            //获取或者设置文件对话框显示的初始目录
            file.InitialDirectory = Environment.GetFolderPath(Environment.SpecialFolder.Desktop);
            //是否允许对话框选择多个文件
            file.Multiselect = false;
            if(file.ShowDialog()==DialogResult.Cancel)
            return null;

            //判断文件后缀
            var path = file.FileName;
            string fileSuffix = System.IO.Path.GetExtension(path);
            if (string.IsNullOrEmpty(fileSuffix))
                return null;
            using (DataSet ds = new DataSet())
            {
                //判断Excel文件是2003版本还是2007版本
                string connString = "";
                if(fileSuffix==".xls")
                    connString="Provider=Microsoft.Jet.OLEDB.4.0;"+"Data Source="+path+";"+";Extended Properties=\"Excel8.0;HDR=YES;IMEX=1\"";
                else
                    connString = "Provider=Microsoft.ACE.OLEDB.12.0;" + "Data Source=" + path + ";" + ";Extended Properties=\"Excel 12.0;HDR=YES;IMEX=1\"";
                //读取文件
                string sql_select = "SELECT*FROM[Sheet1$]";
                using (OleDbConnection conn = new OleDbConnection(connString))
                using (OleDbDataAdapter cmd = new OleDbDataAdapter(sql_select, conn))
                {
                    conn.Open();
                    cmd.Fill(ds);
                }
                if (ds == null || ds.Tables.Count <= 0) return null;
                return ds;
            }

        }

        private void button1_Click(object sender, EventArgs e)
        {
            dataGridView1.DataSource = null;//每次打开清空内容
            DataTable dt = getData().Tables[0];
            dataGridView1.DataSource = dt;
        }
    }
}

  然后呢,拖把拖把就行了,一个Button,一个DataGridView

大功告成

插点闲话:今天30度,热死。一热脑袋就大。

posted on 2018-05-09 15:58  平大爷  阅读(287)  评论(0编辑  收藏  举报

导航