我在 HTML 文件中有一个表,使用下面的 CODE 我设法从该表中获取所有值作为数组。
问题是我的 CODE 使 Array 为:(Key -> Value) (Key -> Value)。但是我的数据结构是:(Key -> Value, Value) (Key -> Value, Value)
以下是内容:myHTMLfile.html
<td height="22" align="center" bgcolor="#FFFFFF">1 Hour </td>
<td align="center" bgcolor="#FFFFFF">400 USD</td>
<td align="center" bgcolor="#FFFFFF">450 USD</td>
<td height="22" align="center" bgcolor="#FFFFFF">2 Hours</td>
<td align="center" bgcolor="#FFFFFF">500 USD</td>
<td align="center" bgcolor="#FFFFFF">600 USD</td>
<td height="22" align="center" bgcolor="#FFFFFF">3 Hours </td>
<td align="center" bgcolor="#FFFFFF">600 USD</td>
<td align="center" bgcolor="#FFFFFF">700 USD</td>
我使用此代码获取内容并制作此数组:
$file = ("myHTMLfile.html");
$searchfor = 'align="center" bgcolor="#FFFFFF"';
header('Content-Type: text/html');
$html = file_get_contents($file);
$pattern = preg_quote($searchfor, '/');
$pattern = "/^.*$pattern.*\$/m";
if(preg_match_all($pattern, $html, $matches));
function remap_alternating(array $values) {
$remapped = array();
for($i = 0; $i < count($values) - 1; $i += 2) {
$remapped[strip_tags(trim($values[$i]))] = strip_tags(trim($values[$i + 1]));
}
return $remapped;
}
$mapped = remap_alternating($matches[0]);
// RAM
$keys = array_map("trim", array_map("strip_tags", array_keys($mapped)));
$values = array_map("trim", array_map("strip_tags", array_values($mapped)));
$mapped = array_combine($keys, $values);
下面你可以看到我得到的结果var_dump($mapped);
array(4) {
["1 Hour"]=>
string(7) "400 USD"
["450 USD"]=>
string(7) "2 Hours"
["500 USD"]=>
string(7) "600 USD"
["3 Hours"]=>
string(7) "600 USD"
}
我希望这个数组结果看起来像:
array(3) {
["1 Hour"]=>
string(16) "400 USD, 450 USD"
["2 Hours"]=>
string(16) "500 USD, 600 USD"
["3 Hours"]=>
string(7) "600 USD"
}
我的问题是:获得我想要的结果的正确 PHP 编程代码是什么?
更新如下
我找到了一个例子,它看起来像我需要的。但是我如何将它与上面的代码一起使用?
例子:
$get = "first=value1&second=value2&third=value3";
print_r(array_map2("explode","=",explode("&",$get)));
会打印出来:
Array
(
[0] => Array
(
[0] => first
[1] => value1
)
[1] => Array
(
[0] => second
[1] => value2
)
[2] => Array
(
[0] => third
[1] => value3
)
)