(一)C#Winform导入Excel数据到datagridview控件

C#Winform导入Excel数据到datagridview控件

#此次导入Excel数据借助了ExcelDataReader插件。(由于我需要的是打开工作簿时能够选择工作表绑定于datagridview控件,通过网上资源的浏览与借鉴,ExcelDataReader能满足我的需求。)

一、插件安装

(1)安装ExcelDataReader插件(如图)
在这里插入图片描述
(2)查看是否安装成功(如图表明已安装成功)
在这里插入图片描述

二、代码编写

(1)为了方便使用,打开文件的过程构造为一个方法

		DataTableCollection tableCollection;
        public void OpenFile()
        {
            OpenFileDialog file = new OpenFileDialog();
            file.Filter = "Excel(*.xlsx)|*.xlsx|Excel(*.xls)|*.xls";
            if (file.ShowDialog() == DialogResult.OK)
            {
                txtFileName.Text = file.FileName;//对话框中选择的文件名
                //1:打开文件,得到文件流stream 
                FileStream stream = File.Open(file.FileName, FileMode.Open, FileAccess.Read);//FileStream:用于文件中任何位置的读写。
                var sw = new Stopwatch();//定时器
                sw.Start();
                //2:得到文件reader
                var reader = ExcelReaderFactory.CreateReader(stream);
                //3:通过reader得到数据
                var result = reader.AsDataSet(new ExcelDataSetConfiguration()
                {
                    ConfigureDataTable = (tableReader) => new ExcelDataTableConfiguration()
                    {
                        //标题行的内容是否显示
                        UseHeaderRow = true
                    }
                });
                var openTiming = sw.ElapsedMilliseconds;
                toolStripStatusLabel1.Text = "Elapsed: " + sw.ElapsedMilliseconds.ToString() + " ms (" + openTiming.ToString() + " ms to open)";
                //4:得到ExcelFile文件的表Sheet
                tableCollection = result.Tables;
                cboSheet.Items.Clear();
                foreach (DataTable item in tableCollection)
                {
                    cboSheet.Items.Add(item.TableName);
                    Console.WriteLine(item.TableName);
                }
                
            }
        }

(2)效果展示(图上为控件name)
在这里插入图片描述
(3)数据绑定方法

	 	public static void BindDataGridView(DataTable dt, DataGridView dgv)
 		{

            /*dgv.ClearSelection();
            //不像用户显示添加行
            dgv.AllowUserToAddRows = false;
            dgv.DataSource = null;*/
            //DataTable存储数据
           	dgv.DataSource = dt;

        }

(4)选择工作表,绑定相应数据

 		private void dgv_CellContentClick()
        {

            //datagridview组件的颜色
            dgvData.RowsDefaultCellStyle.BackColor = Color.White;
            Console.WriteLine(cboSheet.SelectedItem.ToString());
            var dt = tableCollection[cboSheet.SelectedItem.ToString()];

            BindDataGridViewFillShow(dt, dgvData);
            dgvData.DataSource = dt;
            // DataGridView取消选中第一行第一列方法(绑定数据源后)
            dgvData.Rows[0].Cells[0].Selected = false;
            dgvData.Rows[0].Selected = false;
        }

(5)在相应控件调用方法即可

		private void btnFilenpath_Click(object sender, EventArgs e)
        {
            OpenFile();
        }

        private void cboSheet_SelectedIndexChanged(object sender, EventArgs e)
        {
            dgv_CellContentClick();
        }

这就完成将Excel数据导入到Excel的过程啦!

这是通过自己需求从网络上学习、借鉴从而实现的,给有需要的朋友参考参考。如有侵权,请务必联系我删除,谢谢!
也希望能给大家有所帮助!!!

  • 6
    点赞
  • 50
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
可以通过使用 Microsoft.Office.Interop.Excel 库来实现在 C# Winform 中导入多个 Excel 文件到 DataGridView 件中。 以下是一个简单的示例代码,可以实现将多个 Excel 文件的数据导入到一个 DataGridView 中: ```csharp using System; using System.Collections.Generic; using System.Data; using System.IO; using System.Runtime.InteropServices; using System.Windows.Forms; using Excel = Microsoft.Office.Interop.Excel; namespace ExcelToDataGridView { public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void btnImport_Click(object sender, EventArgs e) { OpenFileDialog openFileDialog = new OpenFileDialog(); openFileDialog.Multiselect = true; openFileDialog.Filter = "Excel Files|*.xls;*.xlsx;*.xlsm"; if (openFileDialog.ShowDialog() == DialogResult.OK) { List<DataTable> dataTables = new List<DataTable>(); foreach (string fileName in openFileDialog.FileNames) { DataTable dataTable = ReadExcelFile(fileName); dataTables.Add(dataTable); } dataGridView1.DataSource = MergeDataTables(dataTables); } } private DataTable ReadExcelFile(string fileName) { Excel.Application excelApp = new Excel.Application(); Excel.Workbook workbook = null; Excel.Worksheet worksheet = null; DataTable dataTable = new DataTable(); try { workbook = excelApp.Workbooks.Open(fileName); worksheet = workbook.Sheets[1]; int rowCount = worksheet.UsedRange.Rows.Count; int colCount = worksheet.UsedRange.Columns.Count; for (int i = 1; i <= colCount; i++) { Excel.Range range = worksheet.Cells[1, i]; dataTable.Columns.Add(range.Value.ToString()); } for (int i = 2; i <= rowCount; i++) { DataRow dataRow = dataTable.NewRow(); for (int j = 1; j <= colCount; j++) { Excel.Range range = worksheet.Cells[i, j]; dataRow[j - 1] = range.Value != null ? range.Value.ToString() : ""; } dataTable.Rows.Add(dataRow); } } catch (Exception ex) { MessageBox.Show(ex.Message); } finally { if (worksheet != null) Marshal.ReleaseComObject(worksheet); if (workbook != null) workbook.Close(); if (excelApp != null) excelApp.Quit(); Marshal.ReleaseComObject(excelApp); } return dataTable; } private DataTable MergeDataTables(List<DataTable> dataTables) { DataTable mergedDataTable = new DataTable(); foreach (DataTable dataTable in dataTables) { mergedDataTable.Merge(dataTable); } return mergedDataTable; } } } ``` 在上述代码中,通过 OpenFileDialog 对话框选择多个 Excel 文件后,分别通过 ReadExcelFile 方法读取每个 Excel 文件中的数据,然后将读取的数据通过 MergeDataTables 方法合并成一个 DataTable,并绑定到 DataGridView 件中显示。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值