是否可以使用联赛csv逐列读取csv文件?

时间:2019-06-05 15:10:11

标签: symfony csv

我想知道是否可以使用League csv或其他方式读取以symfony格式编写的csv文件。

      water_level,2,456,345
      wind_speed,25,456,56
      food_level,10.4,123,23
      animal_count,56,34,124
      number_of_machines,150,345,54
      machineId,1234567,1234568,1234567

第一列中的标题,第二列中的数据。

现在,当标题位于第一行时,我可以读取文件,我只想知道是否可以用其他方式读取文件!

我尝试移调,但出现错误。我真的不知道如果真的对数组进行转置是什么原因。

    $pathString = implode($newFilesPath);
    $reader = (Reader::createFromPath($pathString))->setHeaderOffset(0);
    $results = $this->transpose(iterator_to_array($reader->getRecords()));

    foreach ($results as $row) {

        $properties = (new AppProperty)
            ->setWaterLevel($row['water_level'])
            ->setWindSpeed($row['wind_speed'])
            ->setFoodLevel($row['food_level'])
            ->setAnimalCount($row['animal_count'])
            ->setNumberOfMachines($row['number_of_machines'])
            ->setMachineId($row['machineId'])
            ->setDate(new \DateTime());

            $this->em->persist($properties);
    }

    $this->em->flush();
 }

private function transpose ($array){
    return array_map(null, $array);
}

错误:

传递给App \ Entity \ Property :: setWaterLevel()的参数1必须为int或null类型,并给出字符串。
似乎移调不起作用。

0 个答案:

没有答案