Aprende Java Aprende Php Aprende C++ Aprende HTML 5 Aprende JavaScript Aprende JSON Aprende MySQL Aprende SQLServer Aprende Visual Basic 6 Aprende PostgreSQL Aprende SQLite Aprende Redis Aprende Kotlin Aprende XML Aprende Linux VSC Aprende Wordpress Aprende Laravel Aprende VueJS Aprende JQuery Aprende Bootstrap Aprende Netbeans Aprende Android
Sigueme en Facebook Sigueme en Twitter Sigueme en Instagram Sigueme en Youtube Sigueme en TikTok Sigueme en Whatsapp
Home / Desarrollo Web / Importar datos CSV a base de datos usando Laravel Seeder

Importar datos CSV a base de datos usando Laravel Seeder

Por jc mouse viernes, mayo 30, 2025

En este post veremos paso a paso como importar registros de archivos *.CSV a una base de datos (MySQL por ejemplo) usando Laravel Seeder.

Usaremos Laravel Seeder para extraer datos de un archivo *.CSV.

Paso 1. Crea tu archivo CSV

El archivo se llama provinces.csv, importante lo debes guardar como UTF-8 sin BOM (Byte Order Mark).

Es buena practica guardar el archivo en una carpeta «data» dentro de la carpeta «databases» de Laravel.

Para hacer mas facil el trabajo, los nombres de las columnas del CSV deben ser las mismas que los nombres de las columnas del tu tabla.

code;name
BOL-001;Oropeza
BOL-002;Azurduy
BOL-003;Zudáñez
BOL-004;Tomina
BOL-005;Hernando Siles
BOL-006;Yamparáez
BOL-007;Nor Cinti
BOL-008;Belisario Boeto
BOL-009;Sud Cinti
BOL-010;Luis Calvo

Paso 2. En Laravel crea un Seeder de la siguiente manera:

php artisan make:seeder ProvincesSeeder

Paso 3. En el archivo Seeder pega el siguiente código:

<?php

namespace Database\Seeders;

use Illuminate\Database\Console\Seeds\WithoutModelEvents;
use Illuminate\Database\Seeder;
use Illuminate\Support\Facades\DB;

class ProvincesSeeder extends Seeder
{
    const TABLE = 'provinces';
    const CSV_FILE = 'provinces';
    const DELIMITER_CSV = ';';

    /**
     * Run the database seeds.
     */
    public function run(): void
    {
         // Ruta al archivo CSV
        $csvFile = database_path('data/'.self::CSV_FILE.'.csv');
        // Abre el archivo CSV en modo lectura
        if (($handle = fopen($csvFile, 'r')) !== FALSE) {
            // Lee la primera fila (encabezados) para mapear las columnas
            $header = fgetcsv($handle, 1000, self::DELIMITER_CSV);                        

            while (($row = fgetcsv($handle, 1000, self::DELIMITER_CSV)) !== FALSE) {
                // Combina los encabezados con los datos de la fila
                // Esto crea un array asociativo como ['name' => 'Juan Perez', 'email' => '...', etc
                $data = array_combine($header, $row);                        
                $data['created_at'] = now();
                $data['updated_at'] = now();

                // Inserta los datos en la base de datos                
                DB::table(self::TABLE)->insert($data);                
                //Province::create($data);
            }
            fclose($handle);
        } else {
            $this->command->error("No se pudo abrir el archivo CSV: {$csvFile}");
        }
    }
}

Paso 4. Ejecuta la migración:

php artisan migrate:refresh --seed

obtenemos:

Enjoy!!!

Tags

Artículos similares

Primeros pasos con Vue CLI: Crea tu Entorno de Trabajo

En un post anterior [Introducción a VueJS framework para el desarrollo FrontEnd] realizamos una breve introducción a Vue[...]

JASYPT : Cifrado simplificado Java

Jasypt es una biblioteca java que permite agregar capacidades básicas de encriptación a proyectos con el mínimo esfuerzo[...]

Controla excepciones con abort_if() y abort_unless()

Laravel tiene varias formas de tratar con las excepciones de nuetros proyectos, uno de ellos es el helper «abort()», est[...]

La era de la Inteligencia Artificial

The Age of AI o «La era de la Inteligencia Artificial»,  es una serie de 8 documentales de Youtube Original, presentados[...]

NASA y REST API para programadores

La NASA (Administración Nacional de la Aeronáutica y del Espacio) pone en linea Image and Video Library un nuevo Catalog[...]

Conversor de Audio y Video (GRATUITO)

Shutter Encoder es un software de conversión de video el cual tambien maneja audio e imagenes. Su interfaz de usuario ha[...]