定制 wizaplace/php-etl 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

wizaplace/php-etl

最新稳定版本:2.4.0

Composer 安装命令:

composer require wizaplace/php-etl

包简介

Extract, Transform and Load data using this PHP written migration library.

README 文档

README

License CircleCI Version Maintenance Ask Me Anything ! PHP Version

Extract, Transform and Load data using PHP. This library provides classes and a workflow to allow you to extract data from various sources (CSV, DB...), one or many, then transform them before saving them in another format.

You can also easily add your custom classes (Extractors, Transformers and Loaders).

ETL

Versions and compatibility

  • To benefit from the latest features and if you use PHP 8.1 and above: use the 2.3 version (and above) of the library.
  • If you use older versions of PHP: 7.4 or 8.0, use the 2.2 version of the library.
  • If you use older versions of PHP: 7.2 <= PHP <= 7.4, use the legacy 1.3.x version.

Changelog

See the changelog here

Installation

In your application's folder, run:

composer require wizaplace/php-etl

Example ????

In the example below, we will extract data from a csv file, trim white spaces from the name and email columns and then insert the values into the users table:

use Wizaplace\Etl\Etl; use Wizaplace\Etl\Extractors\Csv; use Wizaplace\Etl\Transformers\Trim; use Wizaplace\Etl\Loaders\Insert; use Wizaplace\Etl\Database\Manager; use Wizaplace\Etl\Database\ConnectionFactory; // Get your database settings : $config = [ 'driver' => 'mysql', 'host' => 'localhost', 'port' => '3306', 'database' => 'myDatabase', 'username' => 'foo', 'password' => 'bar', 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', ]; // Instanciate all the components (manually or automatically with DI) $manager = new Manager(new ConnectionFactory()); $manager->addConnection($config); $etl = new Etl(); $extractor = new Csv(); $transformer = new Trim(); $loader = new Insert($manager); $etl->extract($extractor, '/path/to/users.csv') ->transform( $transformer, [Step::COLUMNS => ['name', 'email']] ) ->load($loader, 'users') ->run();

The library is fully compatible with any PHP project. For instance, with Symfony, you can fully benefit from the autowiring. On the following example, you enable it on the main ETL object, with the shared parameter to false in order to have the possibility to get different instance of the ETL (optional).

services.yaml

 Wizaplace\Etl\Etl: shared: false

How to contribute?

Below are some (not exhaustive) welcomed features for a 3.x version.

  • Dropping support of older PHP versions.
  • Type-hinting, rector...
  • Putting PHPCS back on the project.
  • Updating PHPUnit
  • Improve code in order to remove some PHPStan exclusions.

Documentation ????

The documentation is available in a subfolder of the repo, here.

License

WP-ETL is licensed under the MIT license.

Origin of the project

This project is a fork and an improvement of the marquine/php-etl project by Leonardo Marquine.

统计信息

  • 总下载量: 96.03k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 76
  • 点击次数: 3
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 75
  • Watchers: 5
  • Forks: 84
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固