c# - 如何显示列表在数据表中水平?
问题描述
这个问题与我之前的问题有关。在上一个问题中,感谢@EldHasp,我能够任意显示List<int>
in 的许多元素DataGrid
。
现在,我想在 DataTable 中做同样的事情。
我已经试过了;但是,它只显示System.Collections.Generic.List 1[System.In32]
. 我确定我错了,但我不知道如何解决这个问题。虽然我认为AutoGenerateColumns="True"
会自动解决这个问题,但它并没有发生。
这是我的代码:
CatModel.cs(除注释外与上一个相同)
using System;
using System.Collections.Generic;
namespace WpfApp1
{
public class CatModel
{
public CatModel(int Num, String Name, List<int> Test_List)
{
this.Num = Num;
this.Name = Name;
this.Test_List = Test_List;
}
public int Num { get; set; }
public String Name { get; set; }
public List<int> Test_List { get; set; }
}
}
主窗口.xaml.cs
using System.Collections.Generic;
using System.Data;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
namespace WpfApp1
{
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
DataTable result = new DataTable();
result.Columns.Add("Num");
result.Columns.Add("Name");
for (int i = 0; i < 3; i++)
{
result.Columns.Add("Test_" + (i + 1));
}
result.Rows.Add(1, "AA", new List<int> { 1, 2, 3 });
result.Rows.Add(2, "BB", new List<int> { 4, 5, 6 });
result.Rows.Add(3, "CC", new List<int> { 7, 8, 9 });
DataContext = result;
}
}
}
主窗口.xaml
<Window x:Class="WpfApp1.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"
Title="List" Height="350" Width="750"
BorderThickness="1">
<Grid Width="700" Height="300">
<DataGrid IsReadOnly="True" AutoGenerateColumns="True" ItemsSource="{Binding}" HorizontalAlignment="Left" Margin="10,10,10,10"/>
</Grid>
</Window>
解决方案
一个可能的实现示例:
public DataTable Table { get; } = new DataTable();
public MainWindow()
{
List<CatModel> result = new List<CatModel>();
result.Add(new CatModel(1, "AA", new List<int> { 1, 2, 3 }));
result.Add(new CatModel(2, "BB", new List<int> { 4, 5, 6 }));
result.Add(new CatModel(3, "CC", new List<int> { 7, 8, 9 }));
Table.Columns.Add(new DataColumn(nameof(CatModel.Num), typeof(int)));
Table.Columns.Add(new DataColumn(nameof(CatModel.Name), typeof(string)));
for (int i = 0; i < 3; i++)
{
Table.Columns.Add(new DataColumn ($"{i}", typeof(int)));
}
foreach (var cat in result)
{
var row = Table.NewRow();
row[0] = cat.Num;
row[1] = cat.Name;
for (int i = 0; i < 3; i++)
{
row[2 + i] = cat.Test_List[i];
}
Table.Rows.Add(row);
}
InitializeComponent();
}
<Window x:Class="WpfApp1.MainWindow"
x:Name="mainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"
Title="List" Height="350" Width="750"
BorderThickness="1">
<Grid Width="700" Height="300">
<DataGrid IsReadOnly="True" AutoGenerateColumns="True"
ItemsSource="{Binding Table, ElementName=mainWindow}"
HorizontalAlignment="Left" Margin="10,10,10,10"/>
</Grid>
</Window>
PS结果收集是多余的。
我留下它只是因为与问题中的代码有联系,这样表格单元格如何与原始数据链接起来会更清楚。
最好在没有中间集合的情况下立即初始化表。
推荐阅读
- node.js - 表迁移文件
- r - ggplot + geom_bar() 中的条形间距与时间序列数据不一致
- react-native - 接收屏幕之间的参数 React-Native
- python - 使用 matplotlib 将帧号转换为时间戳并在 x 轴上正确绘制
- arrays - 无法从 addSnapshotListener 获取数组数据
- server-side-rendering - 将 Angular 从 8 更新到 11 后,在 SSR 中出现错误:“错误:必须从注入上下文调用注入()”
- javascript - 加载数据时不显示无效的 UI 状态
- python - pyttsx3 不会在 MacOSX Python 3.9 上返回任何音频
- ios - 从旧的 swift 应用程序到新的 ionic 应用程序的用户默认值
- python - 如何有效地关闭和打开 Python 记录器类中的文件