我有一个像这样的数据库
array(
(int) 0 => array(
'B' => array(
'company' => 'KC ACEH'
),
'User' => array(
'company' => 'KCP ACEH DARUSSALAM'
),
(int) 0 => array(
'jumlah' => null,
'jumbuy' => '50990',
'admin' => '50010'
)
),
(int) 1 => array(
'B' => array(
'company' => 'KC LANGSA'
),
'User' => array(
'company' => 'KCP ACEH ULEE KARENG'
),
(int) 0 => array(
'jumlah' => null,
'jumbuy' => '65000',
'admin' => '5000'
)
),
(int) 2 => array(
'B' => array(
'company' => 'KC ACEH'
),
'User' => array(
'company' => 'KCP ACEH DARUSSALAM'
),
(int) 0 => array(
'jumlah' => null,
'jumbuy' => '98990',
'admin' => '2010'
)
)
)
数组第零行和第一行,是同一个月,数组第二行是不同的月份。所以如果名称' User'的数据,我想用foreach实现。 - > '公司'是一样的 。并将输出此数据
array(
(int) 0 => array(
'B' => array(
'company' => 'KC ACEH'
),
'User' => array(
'company' => 'KCP ACEH DARUSSALAM'
),
(int) 0 => array(
'jumlah' => null,
'jumbuy' => '50990',
'admin' => '50010'
),
(int) 1 => array(
'jumlah' => null,
'jumbuy' => '98990',
'admin' => '2010'
)
),
(int) 1 => array(
'B' => array(
'company' => 'KC LANGSA'
),
'User' => array(
'company' => 'KCP ACEH ULEE KARENG'
),
(int) 0 => array(
'jumlah' => null,
'jumbuy' => '65000',
'admin' => '5000'
)
)
)
我正在搜索谷歌搜索,但我不明白。有谁可以帮助我?
答案 0 :(得分:2)
如果来自['B']['company']
的值将是唯一的,那么您可以将其用作分组那些共享那些的数组批次的密钥,然后将其放入另一个容器中。
在初始容器推送时,只需将整批产品与指定的密钥一起推送即可。如果它已经存在,只需获取当前批处理的最后一个元素(数字索引一)并将其推入组中。
$data = array();
foreach($array as $values) {
if(!isset($data[$values['B']['company']])) {
// initialize group
$data[$values['B']['company']] = $values;
} else {
$last_element = array_pop($values); // get last element
$data[$values['B']['company']][] = $last_element; // push
}
}
$data = array_values($data); // re index
答案 1 :(得分:0)
foreach($report_posts as $values) {
if(!isset($data[$values['User']['company']])) {
$data[$values['User']['company']] = $values;
$data1 = array(***OUTPUT JUMBUY***);
$series = $this->HighCharts->addChartSeries();
$series->addName($values['User']['company'])->addData($data1);
$mychart->addSeries($series);
} else {
$last_element = array_pop($values);
$data[$values['User']['company']][] = $last_element;
}
}
$data = array_values($data);