0

我有一个脚本,它通过一个 CSV 文件并将每一行作为一个数组放入另一个数组(嵌套数组?)。每行有 2-3 个字段用于该行中项目的类别。我正在尝试研究如何从这些类别中创建多维数组。这是我目前拥有的来源:

$csv = new File_CSV_DataSource;
if ($csv->load($file)) {
    $items = $csv->getHeaders();
    $csv->getColumn($items[2]);
    if ($csv->isSymmetric()) {
        $items = $csv->connect();
    } else {
        $items = $csv->getAsymmetricRows();
    }
    $items = $csv->getrawArray();
}

$mainCats = array();
$subCats = array();
$subSubs = array();

foreach($items as $item){
    if(!in_array($item[10], $mainCats)){
        $mainCats[] = $item[10];
    }
}

foreach($items as $item){
    if(!array_key_exists($item[11], $subCats)){
        $parent = array_search($item[10], $mainCats);
        $subCats[$item[11]] = $parent;
    }
}

foreach($items as $item){
    if(!array_key_exists($item[12], $subSubs)){
        $parent = array_search($item[11], array_keys($subCats));
        $subSubs[$item[12]] = $parent;
    }
}

到目前为止,它所做的是创建 3 个数组,其格式为:

$mainCats = Array(
    [0] => Main Cat 1,
    [1] => Main Cat 2,
    [2] => Main Cat 3
);

$subCats = Array(
    [Sub Cat 1] => 0,
    [Sub Cat 2] => 1,
    [Sub Cat 3] => 2
);

$subSubs = Array(
    [Sub Sub 1] => 0,
    [Sub Sub 2] => 1,
    [Sub Sub 3] => 2
);

最后 2 个数组中的每一个的数值都是其父类别在前一个数组中的索引。我想做的是将它们全部合并到一个大数组中,格式如下:

$cats = Array(
    [0] => Array(
        'name' => Main Cat 1,
        'subs' => Array(
            [0] => Array(
                'name' => Sub Cat 1,
                'subs' => Array(
                    'name' => Sub Sub 1
                )
            )
        )
    ),
    [1] => Array(
        'name' => Main Cat 2,
        'subs' => Array(
            [0] => Array(
                'name' => Sub Cat 2,
                'subs' => Array(
                    'name' => Sub Sub 2
                )
            )
        )
    ),
    [2] => Array(
        'name' => Main Cat 3,
        'subs' => Array(
            [0] => Array(
                'name' => Sub Cat 3,
                'subs' => Array(
                    'name' => Sub Sub 3
                )
            )
        )
    ),
);

我知道必须有一种更有效的方法来做到这一点,但我无法弄清楚。

编辑 - 我还应该提到,并非所有行都有第三个类别字段值。

4

1 回答 1

0

我更喜欢按名称索引它们:

$cats=array();
//--------
foreach($items as $item){
        $main=$item[10];
        $subCat=$item[11];
        $subSub[$item[12]];
        $cats[$main]['subs'][$subCat]['subsubs'][$subSub]['name']=$subSub;
        $cats[$main]['subs'][$subCat]['name']=$subCat;
        $cats[$main]['name']=$main;



}
于 2012-12-10T04:14:23.993 回答