我在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[]>
之类的内容绑定到ItemsSource
,它只会生成列。它目前正在自动生成列,它只是没有填充string[][]
的内容。
答案 0 :(得分:12)
DataGrid
自动生成列功能并不适合显示锯齿状阵列数据。它更适合单个,一维集合,DataGrid
中的每一行代表集合中的单个项目,每列代表相应项目的不同属性。
除非ItemsSource
中的项目是可以展示的模型,否则您不应该依赖自动生成列功能(它将显示所有属性的列,包括那些不属于显示)。尝试自动绑定DataGrid
到数组时的另一个问题是DataGrid
没有关于如何命名列的信息。
最后,我认为您最好以某种方式定义DataGrid
列,而不是让DataGrid
自行生成列。例如,假设你总是有两个&#34;列,那么可以从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;