合并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;
}