PHP:HTML到PHP多维关联数组

问题描述 投票:0回答:1

使用xPath查询,我试图提取HTML值并将它们放入PHP中的关联数组中。我正在使用循环来从表中获取行和单元格。但是,我可以弄清楚如何将一个数组中的单元格嵌入代表该行的数组中。基本上,只是将表结构转移到数组。理想情况下,它有助于为单元数据分配键。

我尝试将$ key组合为一个数组和一个计数器来分配键/值对。我和xpath在结构的不同点。我可以填满阵列,但我是,但我似乎无法破解它。

$cells = array();
$cell_values = array();
$key = array("MM", "DD", "TIME", "WVHT", "SwH", "SwP", "SwD", "WWH", "WWP", "WWD", "STEEPNESS", "APD");
$i = 3;

while($i <= 5){
    $rows = $xpath->query('//table[@class="dataTable"][2]/tr['.$i.']');
    if (!is_null($rows)){
        foreach ($rows as $row) {
            $cells = $row->getElementsByTagName('td');
            $i++;
            foreach ($cells as $cell) {
                $cell_values[] = $cell->nodeValue;
                $dataOut[] = array_combine($key, $cell_values);
            }
        }   
    }   
}

预期:

Array ( [0] => [1] => [2] => [3] => [4] => [5] => [6] => [7] => [8] => [9] 
=> [10] => 
[11] => Array ( [MM] => 02 [DD] => 17 [TIME] => 11:30 am [WVHT] 
=> 3.0 [SwH] => 0.3 [SwP] => 10.5 [SwD] => SE [WWH] => 2.6 [WWP] => 8.3 
[WWD] => SE [STEEPNESS] => AVERAGE [APD] => 4.4 ) 
//Next set of row data with $keys
[12] => Array ( [MM] => 02 [DD] => 17 [TIME] => 11:00 am [WVHT] => 3.3 [SwH] 
=> 0.3 [SwP] => 10.5 [SwD] => SE [WWH] => 2.6 [WWP] => 8.3 [WWD] => SE 
[STEEPNESS] => AVERAGE [APD] => 4.4 ) 
[13] => Array... etc. 

我得到了什么:

Array ( [0] => [1] => [2] => [3] => [4] => [5] => [6] => [7] => [8] => [9] 
=> [10] => [11] => Array ( [MM] => 02 [DD] => 17 [TIME] => 11:30 am [WVHT] 
=> 3.0 [SwH] => 0.3 [SwP] => 10.5 [SwD] => SE [WWH] => 2.6 [WWP] => 8.3 
[WWD] => SE [STEEPNESS] => AVERAGE [APD] => 4.4 ) [12] => [13] => [14] => 
[15] => [16] => [17] => [18] => [19] => [20] => [21] => [22] => [23] => [24] 
=> [25] => [26] => [27] => [28] => [29] => [30] => [31] => [32] => [33] => 
[34] => [35] => )
php multidimensional-array foreach associative-array
1个回答
0
投票

如果将键定义为$key数组中的值而不是键,则可以使用array_combines中的值来<td>生成结果数组的行。

$rows = $xpath->query('//table[@class="dataTable"][2]/tr');

// define these as values so you can use them in array_combine    
$key = array("WVHT", "SwH", "SwD", "WWH", "WWP", "WWD", "STEEPNESS", "AMD");

$data = array();
$cells = array();

if (!is_null($rows)) {
    foreach ($rows as $row) {
        $cells = $row->getElementsByTagName('td');

        // get all the cell values from the row
        $row_values = [];
        foreach ($cells as $cell) {
            $row_values[] = $cell->nodeValue;
        }

        // combine the keys with the values for this row and add the row to $data
        $data[] = array_combine($key, $row_values);
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.