PHP: многомерный ассоциативный массив HTML to PHP - PullRequest
0 голосов
/ 16 февраля 2019

Используя запрос 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] => )

1 Ответ

0 голосов
/ 16 февраля 2019

Если вы определяете ключи как значения в массиве $key, а не как ключи, вы можете array_combine, используя значения из <td> s, получить строки для вашего массива результатов.

$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);
    }
}
...