合并来自 API 的数据数组

Merge array of data from API

首先,我有一个报告系统,我在其中提取 CSV 数据,返回时状态非常糟糕。

数据拉回方式为:

$data = explode("\t", $site);
$sID = $data[1];
$sCol = $data[2];

等等。

我可以在回显时进一步使用这些变量,这不是问题。

我真正的问题出在上面的数据中,我得到了几个 $sID 这种格式的数据:

20390    Red
20390    Blue
20390    Green
20390    White
20391    Blue
20391    Yellow
20391    Green
20391    White

我想将所有数据合并到一行中,例如:

20390  Red, Blue, Green, White

类似于 array_merge 的东西是理想的,但不确定哪个函数可以复制它。

好的,对于你的情况,我会这样做:

$data = explode("\t", $site[0]);

$final = array();
foreach ($data as $row) {
    if ($row != 0) {
        $info = explode(" ", $row);
        if (isset($final[$info[0]])) {
            array_push($final[$info[0]], "$info[1], $info[2], $info[3], $info[3]");
        } else {
            $final[$info[0]] = array();
            array_push($final[$info[0]], "$info[1], $info[2], $info[3], $info[3]");
        }
    }
}
var_dump($final);

您可以尝试这样的操作:

   $data = explode("\t", $site);
   $s[$data[1]] = array_key_exists($data[1], $s)?($s[$data[1]].', '.$data[2]):$data[2];
foreach($s as $k => $val){
  $sID = $k;
  $sCol = $val;
}