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+,,,,,,,,,
答案 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(),但file_get_contents()除外 以字符串形式返回文件,从指定的偏移量开始直到 maxlen字节。失败时,file_get_contents()将返回FALSE。
应用后返回包含array1的所有元素的数组 每个回调函数。参数的数量 回调函数接受应该匹配传递给的数组的数量 array_map()
以CSV格式解析字段的字符串输入并返回数组 包含读取的字段。
返回包含值的JSON表示的字符串。