2012-09-28 110 views
0

我嘗試比較兩個數組。第一個數組來自我的csv文件,第二個數組是$ a - 數組。我試圖獲得一個csv數據,並添加一個從$ a數組數據的列,如果不會有與csv列2中相同的值($ line 1)然後顯示'空'php循環兩個數組並比較數據

現在它只顯示第一個值從數組 - > a(102019)其他值顯示'空';

由於看到一切都很好,但數組a不循環一次,我錯了?請告訴我......我今天花了整整一天,但沒有發現。

<?php 
    //////////////////////////////////////////////////////////// 

    $file_path="".$_SERVER["DOCUMENT_ROOT"]."/upload/111.csv"; 

    //////////////////////////////////////////////////////////// 

    $a = array('102019','102401','102403','102027','102115','102402','102027'); 

    function get_array_from_csv($file,$delimiter) { 
     if (($handle = fopen($file, "r")) !== FALSE) { 
     $i = 0; 
     while (($lineArray = fgetcsv($handle, 4000, $delimiter)) !== FALSE) { 
      for ($j=0; $j<count($lineArray); $j++) { 
      $data2DArray[$i][$j] = $lineArray[$j]; 
      } 
      $i++; 
     } 
     fclose($handle); 
     } 
     return $data2DArray; 
    } 

    function search($a, $line) { 
     foreach($a as $mas_value) { 
      if (substr($line[1], 2) == $mas_value) { 
       $file = $mas_value; 
      } else { 
       $file = 'empty'; 
      } 
      return $file; 
     } 
    } 

    $data = get_array_from_csv($file_path, ';'); 

    echo '<table>'; 
    foreach ($data as $line) { 

     $file = search($a, $line); 

     echo '<tr> 
     <td>'.$line[0].'</td> 
     <td>'.$line[1].'</td> 
     <td>'.$line[2].'</td> 
     <td>'.$line[3].'</td> 
     <td>'.$line[4].'</td> 
     <td>'.$line[5].'</td> 
     <td>'.$file.'</td> 
     </tr>'; 
    }  
    echo '</table>'; 

    ?> 

這裏是我的輸出數據:

ALFA ROMEO BP102401 156 LIM 4D 1997- 20,00  empty 
    BP102402 156 SPORT WAGON  2000- 20,00  empty 
    BP102403 156 SPORT WAGON ar ugunsdzeЕЎ. 2000- 20,00  empty 
    BP102404 159 -SW  2006- 22,00  empty 
AUDI BP102023 A 1  2010- 22,00  empty 
    BP102023 A 1 Sportback 2010- 22,00  empty 
    BP102001 A 2  2000-2005 15,00  empty 
    BP102010 A 2 German 2000-2005 15,00  empty 
    BP102002 A 3 HB 1996-2003 20,00  empty 
    BP102013 A 3 HB 2003- 20,00  empty 
    BP102004 A 4 AVANT/Combi  1994-2001 20,00  empty 
    BP102012 A 4 AVANT/Combi  2001-2007 20,00  empty 
    BP102019 A 4 AVANT /Combi 2008- 20,00  102019 
    BP102005 A 4 LIM/SED  2000-2008 20,00  empty 
    BP102003 A 4 LIM/SED  1994-2001 20,00  empty 
    BP102018 A 4 LIM/SED  2008- 22,00  empty 
    BP102018 A 5  2007- 22,00  empty 
    BP102022 A 5 SPORTBACK 2009- 25,00  empty 
    BP102007 A 6 AVANT/Combi  1997-2005 20,00  empty 
    BP102016 A 6 AVANT/Combi  2005-2011 25,00  empty 
    BP102026 A 6 AVANT/Combi  2011- 25,00  empty 
    BP102007 A 6 AVANT QUATTRO 1997-2005 20,00  empty 
    BP102006 A 6 LIM/SED  1997-2004 22,00  empty 
    BP102014 A 6 LIM/SED  2004-2011 25,00  empty 
    BP102025 A 6 LIM/SED  2011- 25,00  empty 
    BP102011 A 6 LIM German 1997-2004 22,00  empty 
    BP102007 A 6 ALLOROAD QUATTRO 2000- 20,00  empty 
    BP102024 A 7 SPORTBACK 2010- 25,00  empty 
    BP102027 Q 3 with a tool set located in the trunk 2011- 22,00  empty 
    BP102028 Q 3 with an irregular size spare tire (space saver, smaller than standard tires) 2011- 22,00  empty 

從陣列中的所有值 - 一個必須與$線比較1

Full csv is uploaded here

+0

你的問題是一個數組循環只有一次? – GBD

+0

我覺得這是我第二次看到這個問題呢?你爲什麼刪除前一個? – Baba

+0

我修改了代碼,添加了輸出結果,附上完整的csv文件,所以如果有人能幫我複製這段代碼並嘗試 – Viktors

回答

4

嘗試改變的CSV行中找到你搜索功能如下

function search($a, $line) { 
     $file = 'empty'; 
     foreach($a as $mas_value) { 
      if (substr($line[1], 2) == $mas_value) { 
       $file = $mas_value; 
       break; 
      } 
     } 
     return $file; 
    } 
+0

+1給我的好朋友簡單:) – Baba