为了账号安全,请及时绑定邮箱和手机立即绑定

如何使用PHP和fgetcsv函数从CSV文件创建数组

如何使用PHP和fgetcsv函数从CSV文件创建数组

PHP
一只萌萌小番薯 2019-08-26 11:21:22
如何使用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 回答

?
至尊宝的传说

TA贡献1789条经验 获得超10个赞

就像你在标题中所说,fgetcsv是要走的路。它非常易于使用。

$file = fopen('myCSVFile.csv', 'r');while (($line = fgetcsv($file)) !== FALSE) {
  //$line is an array of the csv elements
  print_r($line);}fclose($file);

如果fopen()失败,您将需要在其中放置更多错误检查,但这可以逐行读取CSV文件并将该行解析为数组。


查看完整回答
反对 回复 2019-08-26
?
哈士奇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;}


查看完整回答
反对 回复 2019-08-26
?
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);


查看完整回答
反对 回复 2019-08-26
  • 3 回答
  • 0 关注
  • 483 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信