如何使用PHP和fgetcsv函数从CSV文件创建数组有人可以使用fgetcsv提供从CSV文件创建数组的代码吗?我使用以下代码从一个简单的CSV文件创建一个数组,但是当我的一个字段有多个逗号(例如地址)时,它无法正常工作。$lines =file('CSV Address.csv');foreach($lines as $data){list($name[],$address[],$status[])= explode(',',$data);}*此外,我的托管服务不支持str_getcsv。以上代码不适用于以下CSV文件示例。第一列是名称,第二列是地址,第三列是婚姻状态。Scott L. Aranda,"123 Main Street, Bethesda, Maryland 20816",SingleTodd D. Smith,"987 Elm Street, Alexandria, Virginia 22301",SingleEdward M. Grass,"123 Main Street, Bethesda, Maryland 20816",MarriedAaron G. Frantz,"987 Elm Street, Alexandria, Virginia 22301",MarriedRyan V. Turner,"123 Main Street, Bethesda, Maryland 20816",Single
3 回答
哈士奇WWW
TA贡献1799条经验 获得超6个赞
我创建了一个将csv字符串转换为数组的函数。该函数知道如何转义特殊字符,它可以使用或不使用机箱字符。
$dataArray = csvstring_to_array( file_get_contents('Address.csv'));
我用你的csv样本尝试了它,它按预期工作!
function csvstring_to_array($string, $separatorChar = ',', $enclosureChar = '"', $newlineChar = "\n") { // @author: Klemen Nagode $array = array(); $size = strlen($string); $columnIndex = 0; $rowIndex = 0; $fieldValue=""; $isEnclosured = false; for($i=0; $i<$size;$i++) { $char = $string{$i}; $addChar = ""; if($isEnclosured) { if($char==$enclosureChar) { if($i+1<$size && $string{$i+1}==$enclosureChar){ // escaped char $addChar=$char; $i++; // dont check next char }else{ $isEnclosured = false; } }else { $addChar=$char; } }else { if($char==$enclosureChar) { $isEnclosured = true; }else { if($char==$separatorChar) { $array[$rowIndex][$columnIndex] = $fieldValue; $fieldValue=""; $columnIndex++; }elseif($char==$newlineChar) { echo $char; $array[$rowIndex][$columnIndex] = $fieldValue; $fieldValue=""; $columnIndex=0; $rowIndex++; }else { $addChar=$char; } } } if($addChar!=""){ $fieldValue.=$addChar; } } if($fieldValue) { // save last field $array[$rowIndex][$columnIndex] = $fieldValue; } return $array;}
HUX布斯
TA贡献1876条经验 获得超6个赞
如果您希望每一行都在一个数组中,并且每行中的每个单元格都在数组中:
$file = fopen('csvFile.csv', 'r'); // Open the file
while (($line = fgetcsv($file)) !== FALSE) { // Read one line
$array[] =$line; // Add the line in the main array
}
echo '<pre>';
print_r($array); //print it out
echo '</pre>';
fclose($file);
- 3 回答
- 0 关注
- 483 浏览
添加回答
举报
0/150
提交
取消