Importing a CSV file with the SplFileObject PHP class

Published on 2024-07-06 • Modified on 2024-07-06

This snippet shows how to import a CSV file with the SplFileObject PHP class. What is excellent about this class is that it will automatically detect separators. Here is a sample of the CSV file:

1,Dupont,Jean,jean.dupont@example.com,25,Paris


<?php

declare(strict_types=1);

namespace App\Controller\Snippet;

/**
 * I am using a PHP trait to isolate each snippet in a file.
 * This code should be called from a Symfony controller extending AbstractController (as of Symfony 4.2)
 * or Symfony\Bundle\FrameworkBundle\Controller\Controller (Symfony <= 4.1).
 * Services are injected in the main controller constructor.
 */
trait Snippet308Trait
{
    public function snippet308(): void
    {
        $csvFile = \dirname(__DIR__, 3).'/data/data.csv';
        $file = new \SplFileObject($csvFile);
        $file->setFlags(\SplFileObject::READ_CSV);
        foreach ($file as $fields) {
            /** @var array<string, string> $fields */
            if (\count(array_filter($fields)) > 0) { // ignore last empty line
                var_dump($fields);
            }
        }

        // That's it! 😁
    }
}

 Run this snippet  More on Stackoverflow   Read the doc  More on the web  Random snippet

  Work with me!


Call to action

Did you like this post? You can help me back in several ways: (use the "reply" link on the right to comment or to contact me )

Thank you for reading! And see you soon on Strangebuzz! 😉

COil