如何上传csv文件并回显json_encode(.csv)


how to upload csv file and echo json_encode($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)。我很难得到这些值。我所做的一切都是徒劳的。

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

您不需要那么多代码,请尝试以下操作:

按照处理文件上传中的说明保存上传的文件,然后:

$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表示形式的字符串。