Значения столбца DataTable для разных кулонов DataTable

У меня есть DataTable с двумя столбцами (Столбец 1 - Имя таблицы, Столбец2 - Имя столбца), т.е.

Table_Name | Columns_Name |

SALES --------------   PROD_ID

SALES ----------------   SALES_ID

CUSTOMER ---------   CUST_ID

CUSTOMER ---------- CUST_NAME 

PRODUCT   ------------ PRODUCT_ID

PRODUCT   ------------ PRODUCT_NAME

Я хотел бы реструктурировать (используя существующий DataTable или создав новый DataTable) данные, добавив каждое имя таблицы и соответствующее поле в другой столбец, т.е.

Table_Name1 | Columns_Name1 |     Table_Name2 | Columns_Name2 |    Table_Name3 | Columns_Name3 |

SALES --------------   PROD_ID   | -----|CUSTOMER ---------   CUST_ID  | ------- |  PRODUCT   ------------ PRODUCT_ID



SALES ----------------   SALES_ID |------ |CUSTOMER ---------   CUST_NAME  | ------ |   PRODUCT   -------- PRODUCT_NAME  

Основная таблица данных будет динамически заполняться различными именами таблиц и столбцов. Не могли бы вы исправить пример кода / цикла, который будет брать каждую таблицу с соответствующим полем и последовательно помещать их в разные столбцы.

1 ответ

Решение
class Program
{
    static void Main(string[] args)
    {
        DataTable table = new DataTable();
        table.Columns.Add("Table_Name", typeof(string));
        table.Columns.Add("Column_Name", typeof(string));

        table.Rows.Add("SALES   ", "PROD_ID     ");
        table.Rows.Add("SALES   ", "SALES_ID    ");
        table.Rows.Add("CUSTOMER", "CUST_ID     ");
        table.Rows.Add("CUSTOMER", "CUST_NAME   ");
        table.Rows.Add("PRODUCT ", "PRODUCT_ID  ");
        table.Rows.Add("PRODUCT ", "PRODUCT_NAME");

        DataTable newTable = RotateDataTable(table, 0);

        foreach (DataRow dataRow in newTable.Rows)
        {
            foreach (var item in dataRow.ItemArray)
            {
                Console.Write("#" + item + "# ");
            }
            Console.WriteLine();
        }
    }

    private static DataTable RotateDataTable(DataTable table, int groupingColumn)
    {

        var grouped = table.AsEnumerable()
                .GroupBy(dr => dr.ItemArray[groupingColumn])
                .Select(grouping => grouping.ToList())
                .ToList();
        int count = grouped.Count;
        int rowCount = grouped[0].Count;
        if (!grouped.All(g => g.Count == rowCount))
            throw new Exception("Unexpected input");


        DataTable newTable = new DataTable();

        for (int i = 0; i < count; i++)
        {
            for (int j = 0; j < table.Columns.Count; j++)
                newTable.Columns.Add(table.Columns[j].ColumnName + (i + j));
        }

        for (int i = 0; i < rowCount; i++)
            newTable.Rows.Add(newTable.NewRow());

        for (int i = 0; i < count; i++)
        {
            var list = grouped[i].ToList();
            for (int j = 0; j < rowCount; j++)
            {
                for (int k = 0; k < list[j].ItemArray.Length; k++)
                {
                    string field = list[j].Field<string>(k);
                    int index = (i * table.Columns.Count) + k;
                    newTable.Rows[j].SetField<string>(index, field);
                }
            }
        }
        return newTable;
    }
}
Другие вопросы по тегам