「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > PHP で列形式のデータ構造を行ベースの形式に転置する方法

PHP で列形式のデータ構造を行ベースの形式に転置する方法

2024 年 11 月 8 日に公開
ブラウズ:804

How to Transpose a Columnar Data Structure into Row-based Format in PHP?

多次元列指向データを行ベースの構造に並べ替える

列指向のデータを含む連想配列が与えられた場合、タスクはそれを転置することです。行で構成される多次元配列。元の配列内のデータは列ごとに配置されており、目的は同じ列の値を行にマージすることです。

元の配列:

$where = [
    'id' => [
        12,
        13,
        14
    ],
    'date' => [
        '1999-06-12',
        '2000-03-21',
        '2006-09-31'
    ]
];

目的の出力:

$comb = [
    [12, '1999-06-12'],
    [13, '2000-03-21'],
    [14, '2006-09-31']
];

解決策:

このデータ再構築を実現する効果的な方法の 1 つは、ループを使用して各列の値を反復処理し、列ごとに配列に結合することです。行。以下に例を示します。

$result = [];

foreach ($where['id'] as $key => $id) {
    $result[] = [$id, $where['date'][$key]];
}

array_column() アプローチ:

ループベースのソリューションに代わる洗練された方法は、多次元データから特定の列を抽出する array_column() 関数を使用することです。配列.

$result = [];

foreach ($where['id'] as $key => $id) {
    $result[] = array_column($where, $key);
}

array_column() 関数は、指定された列を配列として返し、対応する行の値と組み合わせることができます。

出力:

どちらのソリューションでも目的の出力が生成されます:

[
    [12, '1999-06-12'],
    [13, '2000-03-21'],
    [14, '2006-09-31']
]
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3