如何上传csv文件和echo json_encode($ csv)?

时间:2016-05-03 00:56:30

标签: php csv

HTML

<form action="upload.php" method="post" enctype="multipart/form-data">
<input type="file" name="csv" value="" />
<input type="submit" name="submit" value="Save" /></form>
</form>

我需要帮助从上传的csv中读取值。和echo json_encode($ csv)。我无法获得价值观。我尝试的是给我null。

<?php
$csv = array();

// check there are no errors
if($_FILES['csv']['error'] == 0){
    $name = $_FILES['csv']['name'];
    $ext = strtolower(end(explode('.', $_FILES['csv']['name'])));
    $type = $_FILES['csv']['type'];
    $tmpName = $_FILES['csv']['tmp_name'];

    // check the file is a csv
    if($ext === 'csv'){
        if(($handle = fopen($tmpName, 'r')) !== FALSE) {
            // necessary if a large csv file
            set_time_limit(0);


            while(($data = fgetcsv($handle, 10000, ',')) !== FALSE) {
                // number of fields in the csv
                $col_count = count($data);

                // get the values from the csv


            }
array_walk($csv, function(&$a) use ($csv) {
    $a = array_combine($csv[0], $a);
});
array_shift($csv); # remove column header
header('Content-Type: application/json');
echo json_encode($csv); //display array
            fclose($handle);
        }
    }
}

?>

示例csv

LastName,FirstName,MAT251-Calc-I ,MAT252-Calc-II,MAT320-DiscreteMath,CPS210-CompSci-I,CPS310-CompSci-II,CPS315-CompSci-III,CPS352-OOP,CPS330-Assembly.Arch.,CPS353-SoftEng,CPS415-Disc.Cont.Algorithms,CPS340-Op.Sys,CPS425-Lang.Processing,CPS493-Elect-1,CPS493-Projects,EGC230-Dig.Logic,EGC208-Dig.Logic.Lab,SCIENCE-I,SCIENCE-II
Rocha, Cara I.,A,A,A,C-,,,,,,,,,,,,,,
Hamilton, Mufutau N.,B,B,B,A-,,,,,,,,,,,,,,
Castro, Chiquita A.,B,B,C ,C ,,,,,,,,,,,,,,
Juarez, Edward Y.,C+,B,B,C,A,C+,B,B,C,A,C+,B,B,C,A,C+,A,B
Erickson, Norman H.,C-,B-,C+,B,B,B,,C-,B,,,,,,,B,,
Downs, Moana C.,A,C+,B,C-,A,C-,,A-,B+,,,,,,,,,

1 个答案:

答案 0 :(得分:2)

您不需要那么多代码,请尝试这样做:

按照Handling file uploads的说明保存上传的文件,然后:

$file="sample.csv";
$csv= file_get_contents($file);
$array = array_map("str_getcsv", explode("\n", $csv));
$json = json_encode($array);
header('Content-Type: application/json');
print_r($json);

<强>功能

file_get_contents()

  

此函数类似于file(),但file_get_contents()除外   以字符串形式返回文件,从指定的偏移量开始直到   maxlen字节。失败时,file_get_contents()将返回FALSE。

array_map()

  

应用后返回包含array1的所有元素的数组   每个回调函数。参数的数量   回调函数接受应该匹配传递给的数组的数量   array_map()

str_getcsv()

  

以CSV格式解析字段的字符串输入并返回数组   包含读取的字段。

json_encode()

  

返回包含值的JSON表示的字符串。