读取动态创建的数组中的数组值

时间:2018-09-18 09:26:21

标签: php arrays codeigniter

我创建了一个如下数组:

$this->db->order_by('mnth','desc');
$this->db->select("users.name,users.address,awards.*");
$this->db->from('users');
$this->db->join('awards', 'users.sno = awards.mem');
$res = $this->db->get();
$resbygroup = array();
foreach($res->result_array() as $row)
{
 $resbygroup[$row['mnth'].",".$row['yr']][]=($row['name'] . ", " . $row['address']);
}
if($res->num_rows()>0)
{
 return $resbygroup;
}
else
{
  return false;
}

目的是显示按月和年分组的获奖者名单。 在视图中,将var_dump放在返回结果上时,将得到以下输出:

array(3) { ["9,2018"]=> array(5) { [0]=> string(6) "name1, addr1" [1]=> string(31) "name2, addr2" [2]=> string(30) "name3, addr3" [3]=> string(37) "name4, addr4" [4]=> string(46) "name5, addr5" } ["8,2018"]=> array(1) { [0]=> string(46) "name7, addr7" } ["6,2018"]=> array(1) { [0]=> string(24) "name8, addr8" } } 

我想获取结果并将其显示为“年月”。 我尝试了以下代码:

foreach($res as $r)
{
 for($x=0;$x<count($r);$x++)
 {
  echo"<br>";
  echo $r[$x];
  echo"<br>";
 }
}

它完美地显示了名称和地址对,但我也想显示第mn,yr对。输出应为:

  

2018年9月:name1,address1 |名称2,地址2 | name3,address3等

     

2018年8月:姓名7,地址7 |等等

请告诉我们如何实现

1 个答案:

答案 0 :(得分:1)

请尝试以下代码:

foreach($res as $r=>$val)
{
 echo $r; // gives mnth,yr
 for($x=0;$x<count($val);$x++)
 {
 echo $val[$x]; //gives name,address
 }
}