DataGridView表的动态自动创建

文章介绍了如何利用枚举类型中的描述属性和自定义标记,实现DataGridView列名的中文显示,并根据标记控制列的可见性,同时生成对应的DataTable数据源。
摘要由CSDN通过智能技术生成

我想用枚举类型中的参数做来datagridview表的列名。希望列名用中文显示在枚举描述上中文。能过循环的方式生成表,同时还生成一个同样的datatable表。datatable作为datagridview的数据源。

希望在定义枚举类型时就设置某些列为不显示,可以在枚举类型中添加一个标记,然后在生成列的过程中根据这个标记来决定是否显示列。这样可以使方法更加通用,方便统一管理需要隐藏的列。

public enum MyEnum
{
    [Description("学生姓名")]
    StudentName,
    [Description("学生年龄")]
    StudentAge,
    [Description("学生性别"), HiddenColumn]
    StudentGender
}

public partial class Form1 : Form
{
    public Form1()
    {
        InitializeComponent();

        // 创建 DataGridView
        DataGridView dataGridView = new DataGridView();
        Controls.Add(dataGridView);

        // 创建 DataTable
        DataTable dataTable = new DataTable();

        // 根据枚举类型生成 DataGridView 列和 DataTable 结构
        foreach (MyEnum value in Enum.GetValues(typeof(MyEnum)))
        {
            // 获取枚举值的描述
            FieldInfo field = value.GetType().GetField(value.ToString());
            DescriptionAttribute attribute = (DescriptionAttribute)field.GetCustomAttribute(typeof(DescriptionAttribute));
            string columnDisplayName = attribute.Description;

            // 为 DataTable 添加列
            dataTable.Columns.Add(value.ToString());

            // 检查是否含有 HiddenColumn 标记,若有则不显示该列
            if (!Attribute.IsDefined(field, typeof(HiddenColumn)))
            {
                // 为 DataGridView 添加列
                dataGridView.Columns.Add(value.ToString(), columnDisplayName);
            }
        }

        // 将 DataTable 设置为 DataGridView 的数据源
        dataGridView.DataSource = dataTable;
    }
}

  • 8
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值