c# - 如何使用 DataTable 作为 DataGrid 的 ItemsSource

标签 c# wpf dataset closedxml

我想将 Excel 文件加载到我的 DataGrid 中。使用ClosedXML

我有这个方法:

public static DataTable ImportExceltoDataTable(string filePath, string sheetName) {

    using (XLWorkbook wb = new(filePath)) {

        IXLWorksheet ws = wb.Worksheet(1);
        DataTable dt = new();

        bool firstRow = true;
        foreach (IXLRow row in ws.Rows()) {

            if (firstRow) {
                foreach (IXLCell cell in row.Cells()) {
                    dt.Columns.Add(cell.CachedValue.ToString());
                }
                
                firstRow = false;

            } else {
      
                dt.Rows.Add();
                int i = 0;
          
                foreach (IXLCell cell in row.Cells(row.FirstCellUsed().Address.ColumnNumber, row.LastCellUsed().Address.ColumnNumber)) {
                
                    dt.Rows[dt.Rows.Count - 1][i} = cell.CachedValue.ToString();
                    i++;
                }
            }
        }
 
        return dt;
    }
}

这是我的点击事件:

OpenFileDialog of = new();
of.Filter = "Excel Files | *.xlsx;";
of.Title = "Import Excel file.";

if (of.ShowDialog()==true) {

    dataGrid.ItemsSource = ImportExceltoDataTable("...", "...").DefaultView;
}

我正在努力实现以下目标

  • 单击一个按钮,选择一个 Excel 文件,用其内容填充我的 DataGrid

添加@mm8提供的解决方案后更新:

我现在收到不支持空扩展错误,因为我不知道如何将点击事件的OpenFileDialog选择连接到启动DataTable 的。

非常感谢您的帮助!

最佳答案

您可以将ItemsSource设置为DataTableDefaultView:

dataGrid.ItemsSource = ImportExceltoDataTable("...", "...").DefaultView;

DataTable 不同,DataView 实现所需的 IEnumerable 接口(interface)。

关于c# - 如何使用 DataTable 作为 DataGrid 的 ItemsSource,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69076609/

相关文章:

wpf - 如何在增加窗口高度的同时增加 WPF 中控件的高度?

WPF 绑定(bind)渲染 Gui 进度

c# - 如何更改表适配器的命令超时

c# - 投票有什么问题?

c# - 是否可以只在 ASP.Net 中处理 404 错误?

c# - 在 asp.net 中使用 ajax 访问 C# 方法?

c# - 如何使取消按钮像 "X"按钮一样工作?

c# - Visual Studio 中 KeyDown 事件、KeyPress 事件和 KeyUp 事件的区别

python - 数据集中的 load_dataset ('multi_nli' )无法正常工作,出现导入错误

c# - 将 select new 转换为 DataTable?