0

とてもばかげたことをしたような気がしますが、それが何なのかわかりません。
によって生成された配列の配列を実行していますfgetcsv()。私が欲しいのは、ある行の値が次の行の値と異なる場所で配列を2つに分割することです。
このコードにより、$first1つを除くすべての配列が$second保持され、最後の配列が保持されます。文字列の比較は完全に無視されます。strcmp()同じ結果になります。

$csv = array();
$file = fopen('A.csv', 'r');
while (($result = fgetcsv($file)) !== false)
{
    $csv[] = $result;
}
fclose($file);

array_shift($csv); //gets rid of the CSV headers
$rows = count($csv);

for ($i = 0; $i <= $rows; $i++){
    if ($csv[$i][1] != $csv[$i+1][1]){
        $first = array_slice($csv, 0, $i);
        $second = array_slice($csv, $i);
    }
}

CSVファイルの例を次に示します。

NAME,MATCHNAME,CHROMOSOME,START LOCATION,END LOCATION,CENTIMORGANS,MATCHING SNPS
A,person_one,2,20945970,23287731,2.48,500
A,person_one,2,233444593,234432885,1.56,500
A,person_one,4,99184637,100861136,1.24,500
A,person_two,1,154990798,157871980,2.8,700 //Here's where the new array should start
A,person_two,1,67136078,70785393,2.28,800

編集:$firstこの例に期待するのは次のとおりです。

Array
(
[0] => Array
    (
        [0] => A
        [1] => person_one
        [2] => 2
        [3] => 20945970
        [4] => 23287731
        [5] => 2.48
        [6] => 500
    )

[1] => Array
    (
        [0] => A
        [1] => person_one
        [2] => 2
        [3] => 233444593
        [4] => 234432885
        [5] => 1.56
        [6] => 500
    )

[2] => Array
    (
        [0] => A
        [1] => person_one
        [2] => 4
        [3] => 99184637
        [4] => 100861136
        [5] => 1.24
        [6] => 500
    )
)

そして、私の期待$secondは次のとおりです。

Array
(
[0] => Array
    (
        [0] => A
        [1] => person_two
        [2] => 1
        [3] => 154990798
        [4] => 157871980
        [5] => 2.8
        [6] => 700
    )

[1] => Array
    (
        [0] => A
        [1] => person_two
        [2] => 1
        [3] => 67136078
        [4] => 70785393
        [5] => 2.28
        [6] => 800
    )
)
4

1 に答える 1

1

やりたいことをやっていますが、最後の反復に到達すると、最後の行にあるものをと比較するnullので、とを上書き$firstします$second

割り当ての後に追加break;して、条件が満たされたときにループから抜け出してみてください。

于 2012-11-28T03:57:23.713 に答える