C# DataGridView行列转换的具体实现

 更新时间:2023年02月07日 16:06:28   作者:爱编码的波哥  
本文主要介绍了C# DataGridView行列转换的具体实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

初始表格

在这里插入图片描述

需要进行行列转置 转换后的效果

在这里插入图片描述

实现代码如下

 void InitTable()
        {
            var dataTable = new DataTable();
            dataTable.Columns.Add("姓名");
            dataTable.Columns.Add("年龄");
            dataTable.Columns.Add("地址");
            dataTable.Rows.Add("用户1", "1岁", "住址1");
            dataTable.Rows.Add("用户2", "2岁", "住址2");
            dataTable.Rows.Add("用户3", "3岁", "住址3");
            dataTable.Rows.Add("用户4", "4岁", "住址4");
            dataTable.Rows.Add("用户5", "5岁", "住址5");

            //转置table
            var dvgTable = DataTableRowConvertToColumn(dataTable);
            magicDataGridView1.DataSource = dvgTable;
        }

        DataTable DataTableRowConvertToColumn(DataTable dataTable)
        {
            var dvgTable = new DataTable();
            dvgTable.Columns.Add("列名");
            for (int i = 1; i <= dataTable.Rows.Count; i++)
            {
                dvgTable.Columns.Add(i.ToString());
            }
            for (int i = 0; i < dataTable.Columns.Count; i++)
            {
                object[] obj = new object[dataTable.Rows.Count + 1];
                obj[0] = dataTable.Columns[i].ColumnName;
                for (int j = 1; j <= dataTable.Rows.Count; j++)
                {
                    obj[j] = dataTable.Rows[j - 1][i];
                }
                dvgTable.Rows.Add(obj);
            }
            return dvgTable;
        }

到此这篇关于C# DataGridView行列转换的具体实现的文章就介绍到这了,更多相关C# DataGridView行列转换内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

最新评论