【问题标题】:How to use DataTable as ItemsSource of my DataGrid如何使用 DataTable 作为我的 DataGrid 的 ItemsSource
【发布时间】:2021-11-03 15:58:34
【问题描述】:

我想将一个 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提供的解决方案后更新:

我现在收到Empty extension is not supported 错误,因为我不知道如何将点击事件的OpenFileDialog-selection 连接到DataTable 的启动。

非常感谢您的帮助!

【问题讨论】:

  • “绑定”是什么意思?如果将方法返回的值写入属性;此属性通过 INotifyPropertyChanged.PropertyChanged 事件通知其更改;并在 XAML 中元素的 UI 属性设置 {Binding ....} 从这个属性与 DataTable - 那么应该没有任何问题。

标签: c# wpf dataset closedxml


【解决方案1】:

可以将ItemsSource设置为DataTableDefaultView

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

DataTable 不同,DataView 实现了所需的IEnumerable 接口。

【讨论】:

  • 我明白了,谢谢。除了我的方法,我还有一个点击事件。我无法将两者结合起来。我将在我最初的问题中添加一些代码。如果您不介意,请看一下。
  • 如果您还有其他问题,请提出新问题。您究竟从哪里得到异常?
  • using (XLWorkbook workBook = new(filePath)) { 不是在和OpenFileDialog 交谈,是吗?所以我想它没有得到我选择的文档的文件路径并没有那么奇怪(假设这是问题)
  • 您最初的问题是关于“如何使用 DataTable 作为我的 DataGrid 的 ItemsSource”,我相信它已经得到了回答。
  • 你是对的,我将编辑我的问题,并将你的答案设置为接受的答案。
猜你喜欢
  • 2021-04-02
  • 2011-08-23
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-07-25
  • 2010-10-04
  • 1970-01-01
相关资源
最近更新 更多