2016-12-27 163 views
0

我有這種表的如何合併兩個不同陣列的兩個不同的值在PHP笨

aa

我想這樣

a

我已經賺得菜取數據名稱(文本),但我也需要它的ID在一個單一的數組,我怎麼能這樣做? 我的代碼如下: 控制器: -

function fetch() 
    { 
     $this->load->model('fetch'); 
     $d=$this->fetch->call(); 
     $e=$d->result(); 
     $max=$d->num_rows(); 
     for($i=0;$i<$max;$i++){ 
      $a[$i]=$e[$i]->product; 
      $a2[$i]=$e[$i]->id; 
      $b[]=explode(',',$a[$i]); 
     } 
     echo '<pre>'; 
     print_r($a2); 
     $array['arr'] = call_user_func_array('array_merge', array_map('array_values', $b)); 
     $this->load->view('display',$array); 
    } 

型號: -

function call() 
    { 
     $this->db->select('*'); 
     $this->db->from('ruff'); 
     $query = $this->db->get(); 
     if ($query->num_rows() > 0) { 
      return $query; 
     } else { 
      return false; 
     } 
    } 

查看: -

<body> 
<input type="text" name="item" id="txt_search" list="item_list"> 
<datalist id="item_list"> 
    <?php 
     foreach($arr as $a) 
     { 
      echo "<option>".$a."</option>"; 
     } 
    ?> 
</datalist> 
</body> 

在此先感謝。

回答

0

在你的控制器試試這個...代碼

$this->load->model('fetch'); 
    $d=$this->fetch->call(); 
    $e=$d->result_array(); 
    // $max=$d->num_rows(); 
    $products=''; 
    foreach ($e as $p) { 
     $products.=$p['product']; 
    } 

    $data=explode(',', $products); 

    echo '<pre>'; 
    print_r($data); 
    echo '</pre>'; 
0

通常訪問數據庫功能的控制器是不是一個好的做法。因此,爲了滿足計數物品的需要,您可以更改模型以返回一系列物品。

型號:

function call() 
{ 
    $data = array(); 

    $this->db->select('*'); 
    $this->db->from('ruff'); 
    $query = $this->db->get(); 

    if ($query->num_rows() > 0) { 
     foreach($query->result() as $row){ 
      $data[] = (array)$row; 
     } 
     return $data; 
    } else { 
     return false; 
    } 
} 

然後,在你的控制器fetch功能,可以在爆炸現場product並創建另一個陣列遞交給您的視圖。

控制器:

function fetch() 
{ 
    $this->load->model('fetch'); 
    $d=$this->fetch->call(); 

    $list = array(); 

    foreach($d as $row) 
    { 
     $products = explode(',', $row['product']); 
     foreach($products as $p) 
     { 
      $list[] = array('id' => $row['id'], 'product' => $p); 
     } 
    } 

    $this->load->view('display',array('arr' => $list)); 
} 

這將導致你有一個像下面的一個數組:

Array 
(
[0] => Array 
    (
     [id] => 1 
     [product] => veg. burger 
    ) 

[1] => Array 
    (
     [id] => 1 
     [product] => non-veg burger 
    ) 

[2] => Array 
    (
     [id] => 1 
     [product] => chees burger 
    ) 

[3] => Array 
    (
     [id] => 2 
     [product] => vadapau 
    ) 

[4] => Array 
    (
     [id] => 2 
     [product] => butter vadapau 
    ) 

[5] => Array 
    (
     [id] => 2 
     [product] => chees vadapau 
    ) 
) 

現在你的ID是提供你的看法。

查看:

<body> 
    <input type="text" name="item" id="txt_search" list="item_list"> 
    <datalist id="item_list"> 
    <?php 
     foreach($arr as $a) 
     { 
      echo "<option>".$a['product']."</option>"; 
      //$a['id'] 
     } 
    ?> 
    </datalist> 
</body> 
0

這裏是你的模型代碼。

public function call() 
{ 
    $query = $this->db->select("id,product") 
         ->from("stuff") 
         ->get(); 
    if ($query->num_rows() > 0) { 
     return $query->result_array(); 
    } else { 
     return false; 
    } 
} 

現在您將在控制器中獲得結果數組數據。這是控制器功能。

public function fetch() 
{ 
    $this->load->model('fetch'); 

    $result = $this->fetch->call(); 
    foreach ($result as $value) { 
     $newArr = explode(',',$value['product']); 
     foreach ($newArr as $val) { 
      $productArray[] = array('productID'=>$value['id'],"product"=>$val); 
     } 
    } 
    $data['finalArray'] = $productArray; 
    $this->load->view('display',$data); 

} 

現在訪問視圖中的最終產品數組。這裏是視圖代碼。

<input type="text" name="item" id="txt_search" list="item_list"> 
<table id="item_list" border="1"> 
    <?php 

     foreach($finalArray as $stuffs) 
     { 
      echo "<tr>"; 
      echo "<td>".$stuffs['productID']."</td>"; 
      echo "<td>".$stuffs['product']."</td>"; 
      echo "</tr>"; 
     } 
    ?> 
</table> 

乾杯!

0

它非常簡單的代碼,請下面的代碼 模型下面的代碼:

型號: -

function call() { return $this->db->get('ruff')->result_array(); }

這個代碼給你所有的數據現在控制器代碼象下面

控制器: -

function fetch() { $this->load->model('fetch'); $array['arr'] = $this->fetch->call(); $this->load->view('display',$array); }

這個代碼給你所有的數據現在控制器代碼象下面

控制器: -

function fetch() { $this->load->model('fetch'); $array['arr'] = $this->fetch->call(); $this->load->view('display',$array); } 這個代碼給你所有的數據現在控制器代碼象下面

控制器: -

function fetch() { $this->load->model('fetch'); $array['arr'] = $this->fetch->call(); $this->load->view('display',$array); }

現在請寫代碼在視圖中 查看: -

` 這個代碼給你所有的數據現在控制器代碼象下面

控制器: - function fetch() { $this->load->model('fetch'); $array['arr'] = $this->fetch->call(); $this->load->view('display',$array); }

現在可以寫代碼視圖 查看: -

<body> <input type="text" name="item" id="txt_search" list="item_list"> <datalist id="item_list"> <?php foreach($arr as $value){ $newarray=explode(',',$value); foreach($newarray as $test) { echo "<option value=".$arr['id'].">".$test['product']."</option>"; } } ?> </datalist> </body>

我認爲這段代碼將幫助你 謝謝

相關問題