按组将datatable转换为重叠的多维数组
创始人
2024-09-03 01:30:44
0

以下是将DataTable转换为重叠多维数组的示例代码:

using System;
using System.Data;

public class Program
{
    public static void Main()
    {
        // 创建一个示例的DataTable
        DataTable dt = new DataTable();
        dt.Columns.Add("Group", typeof(int));
        dt.Columns.Add("Item", typeof(string));
        dt.Columns.Add("Value", typeof(int));

        dt.Rows.Add(1, "A", 10);
        dt.Rows.Add(1, "B", 20);
        dt.Rows.Add(2, "C", 30);
        dt.Rows.Add(2, "D", 40);
        dt.Rows.Add(2, "E", 50);
        dt.Rows.Add(3, "F", 60);

        // 将DataTable转换为重叠的多维数组
        int maxGroup = Convert.ToInt32(dt.Compute("MAX([Group])", ""));

        int[][][] array = new int[maxGroup][][];

        foreach (DataRow row in dt.Rows)
        {
            int group = Convert.ToInt32(row["Group"]) - 1;
            string item = row["Item"].ToString();
            int value = Convert.ToInt32(row["Value"]);

            if (array[group] == null)
            {
                array[group] = new int[1][];
                array[group][0] = new int[] { value };
            }
            else
            {
                int[][] groupArray = array[group];
                int[][] newArray = new int[groupArray.Length + 1][];
                Array.Copy(groupArray, newArray, groupArray.Length);
                newArray[groupArray.Length] = new int[] { value };
                array[group] = newArray;
            }
        }

        // 输出重叠的多维数组
        for (int i = 0; i < array.Length; i++)
        {
            Console.WriteLine("Group {0}:", i + 1);
            foreach (int[] groupArray in array[i])
            {
                Console.WriteLine("[{0}]", string.Join(", ", groupArray));
            }
            Console.WriteLine();
        }
    }
}

这段代码首先创建了一个示例的DataTable,然后使用循环遍历DataTable的每一行,将每一行的数据按照“Group”列的值转换为重叠的多维数组。最后,输出转换后的多维数组。

请注意,这段代码假设“Group”列的值是连续的整数,并且从1开始。如果不是这种情况,可能需要进行额外的处理。

相关内容

热门资讯

程序员教你!超凡辅助app链接... 程序员教你!超凡辅助app链接(白金岛手游放炮罚有挂)切实有作弊器开挂辅助工具(有挂猫腻);白金岛手...
玩家必看教程!518互游辅助(... 【福星临门,好运相随】;玩家必看教程!518互游辅助(如何做方片十三张脚本)从前有作弊器开挂辅助黑科...
玩家必看教程!新海豚辅助工具(... 玩家必看教程!新海豚辅助工具(微友助手破解版)好像有作弊挂开挂辅助神器(有挂秘笈);1、让任何用户在...
分享一款!新众亿软件可以安装(... 分享一款!新众亿软件可以安装(福州十八扑外卦)一向有作弊挂开挂辅助下载(今日头条);分享一款!新众亿...
实测教程!新财神正版辅助挂(游... 实测教程!新财神正版辅助挂(游戏辅助器免费版)其实有作弊挂开挂辅助插件(有挂辅助);游戏辅助器免费版...
玩家必看!新九哥智能辅助软件(... 玩家必看!新九哥智能辅助软件(小程序能不能开挂)确实有作弊器开挂辅助神器(有挂技巧);新九哥智能辅助...
信息共享!火神工作室辅助大全(... 信息共享!火神工作室辅助大全(朋友圈辅助软件)果然有作弊挂开挂辅助神器(有挂工具);一、火神工作室辅...
玩家必看科普!樱花之盛免费挂(... 玩家必看科普!樱花之盛免费挂(边锋老友辅助)固有有作弊挂开挂辅助脚本(有挂秘籍);亲真的是有正版授权...
总算清楚!天天微友辅助神器(上... 总算清楚!天天微友辅助神器(上饶打炸辅助)最初有作弊器开挂辅助工具(确实有挂);天天微友辅助神器 a...
科技新动态!微友辅助神器下载(... 科技新动态!微友辅助神器下载(人海大厅脚本)最初有作弊挂开挂辅助神器(有挂头条);科技新动态!微友辅...