我在DataGrid里面有一个UserControl。看起来像这样:

<UserControl x:Class="ExternalDataSourceComparison.ImportedInfoGrid"
         xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
         xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
         xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
         xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
         mc:Ignorable="d"
         d:DesignHeight="300" d:DesignWidth="300"
         Height="Auto" Width="Auto">
<Grid>
    <Grid.RowDefinitions>
        <RowDefinition/>
    </Grid.RowDefinitions>
    <DataGrid Name="_dataGrid" Grid.Row="0">
        <DataGrid.Columns>
            <DataGridTextColumn Binding="{Binding Path[0].Length}"/>
        </DataGrid.Columns>
    </DataGrid>
</Grid>

我的UserControl中有MainWindow,看起来像这样:
<Window x:Class="ExternalDataSourceComparison.MainWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="clr-namespace:ExternalDataSourceComparison"
    Title="MainWindow" Height="350" Width="525" WindowState="Maximized">
<Grid>
    <Grid.RowDefinitions>
        <RowDefinition/>
        <RowDefinition Height="Auto"/>
    </Grid.RowDefinitions>
    <local:ImportedInfoGrid x:Name="ExternalData" Grid.Row="0"/>
    <StackPanel Height="36px" Orientation="Horizontal" Grid.Row="1">
        <Button Name="_import" Content="Import Data" Margin="5" Padding="5, 2" Click="Import_Click"/>
        <Button Name="_compare" Content="Compare" Margin="5" Padding="5, 2" Click="Compare_Click"/>
        <Button Name="_cancel" Content="Cancel" Margin="5" Padding="5, 2" Click="Cancel_Click"/>
    </StackPanel>
</Grid>

在我使用fs.CSVToStringArray方法在窗口后面的代码中,我打开了一个CSV文件,并将内容解析为string[][],外部数组代表行,内部数组是所有列,因此string [0] [3]将在第1列第4列。

在后面的代码中,我仅将ItemsSource设置为等于数组的数组,如下所示:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using System.Data;

namespace ExternalDataSourceComparison
{
    /// <summary>
    /// Interaction logic for MainWindow.xaml
    /// </summary>
    public partial class MainWindow : Window
    {
        FileStuff fs = new FileStuff();
        public MainWindow()
        {
            InitializeComponent();
        }

        private void Import_Click(object sender, RoutedEventArgs e)
        {
            string[][] array = fs.CSVToStringArray();
            this.ExternalData._dataGrid.ItemsSource = array;
        }

        private void Cancel_Click(object sender, RoutedEventArgs e)
        {

        }

        private void Compare_Click(object sender, RoutedEventArgs e)
        {

        }
    }
}

输出不是我所期望的。我认为它显示的是对象的属性,而不是实际的内容。有没有一种方法可以自动生成行和列,还是我必须编写代码来创建列和构建行?我认为使用DataGrid可以将诸如string[][]List<string[]>之类的内容绑定(bind)到ItemsSource上,它只会生成列。它当前正在自动生成列,只是没有用string[][]的内容填充它们。

最佳答案

DataGrid的自动生成列功能不太适合显示锯齿状数组数据。它更适合于单维的集合,其中DataGrid中的每一行代表集合中的单个项目,而每一列代表相应项目的不同属性。

并且,除非ItemsSource中的项目是可以显示的模型,否则您不应该依赖自动生成列功能(它将为所有属性显示列,包括那些不打算显示的属性)。尝试自动将DataGrid绑定(bind)到数组时,另一个问题是DataGrid没有有关应如何命名列的信息。

最后,我认为您最好以某种方式定义DataGrid列,而不是让DataGrid自行生成列。例如,假设您在数组中始终有两个“列”,则可以从XAML定义它:

<DataGrid Name="_dataGrid" Grid.Row="0" AutoGenerateColumns="False">
    <DataGrid.Columns>
        <DataGridTextColumn Header="Column 1" Binding="{Binding [0]}"/>
        <DataGridTextColumn Header="Column 2" Binding="{Binding [1]}"/>
    </DataGrid.Columns>
</DataGrid>

或从代码中定义列,以防您具有动态的列数,例如:
string[][] array = fs.CSVToStringArray();
for (int i = 0; i < array[0].Length; i++)
{
    var col = new DataGridTextColumn();
    col.Header = "Column " + i;
    col.Binding = new Binding(string.Format("[{0}]", i));
    _dataGrid.Columns.Add(col);
}
this.ExternalData._dataGrid.ItemsSource = array;

关于c# - 如何自动将字符串数组绑定(bind)到WPF DataGrid?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/22922533/

10-14 14:56
查看更多