我在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/