2012-09-28 2 views
0

나는 두 개의 배열을 비교하려고합니다. 첫 번째 배열은 내 CSV 파일에서 가져온 것이고 두 번째 배열은 $ a - 배열입니다. 나는 csv 데이터를 얻고 $ csv 열 2 ($ line 1)와 같은 값을 가지지 않으면 $ a 배열 데이터에서 더 많은 열을 추가하려고한다.PHP 루프 두 배열 및 데이터 비교

이제 첫 번째 값만 보여준다. array -> a (102019) 다른 값들은 'empty'를 보여줍니다;

모든 것이 좋지만 배열은 한 번만 반복되지 않습니다. 어디에서 잘못 되었나요? 보여주세요 ... 오늘 하루 종일 씁니다. 그러나 아무것도 발견되지 않았습니다. 여기

<?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 

모든 값 - A는 $ 라인 변경 1

Full csv is uploaded here

+0

문제는 $ a 배열 루프가 한 번만 통과합니까? – 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