承接 phpsoftbox/spreadsheet-parser 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

phpsoftbox/spreadsheet-parser

Composer 安装命令:

composer require phpsoftbox/spreadsheet-parser

包简介

Tabular file import component for the PhpSoftBox framework

README 文档

README

SpreadsheetParser — компонент импорта табличных файлов CSV/XLSX для PhpSoftBox.

Возможности

  • parse(...) по definition с явным выбором драйвера (CSV/XLSX);
  • в parse(...) тип не определяется автоматически: драйвер задаётся definition;
  • источник импорта как путь к файлу или сырой контент;
  • чтение CSV/XLSX;
  • выбор листа Excel (по умолчанию первый, по индексу, по имени);
  • определение заголовков и маппинг строк в ассоциативные массивы;
  • пропуск пустых строк;
  • проверка обязательных колонок;
  • валидация строк через ApiSchema/Validator;
  • ошибки по строкам;
  • лимиты на размер файла, число строк и колонок;
  • поддержка CSV кодировок UTF-8, Windows-1251, автоопределение;
  • безопасное чтение XLSX без выполнения формул;
  • логирование через Psr\Log\LoggerInterface.

Быстрый старт (definition API)

use PhpSoftBox\SpreadsheetParser\AbstractImportDefinition;
use PhpSoftBox\SpreadsheetParser\CsvOptions;
use PhpSoftBox\SpreadsheetParser\ImportDriver;
use PhpSoftBox\SpreadsheetParser\ImportOptions;
use PhpSoftBox\SpreadsheetParser\ImportSource;
use PhpSoftBox\SpreadsheetParser\RowMapResult;
use PhpSoftBox\SpreadsheetParser\SpreadsheetParser;

$definition = new class extends AbstractImportDefinition {
    public function driver(): ImportDriver
    {
        return ImportDriver::CSV;
    }

    public function options(): ImportOptions
    {
        return new ImportOptions(
            csv: new CsvOptions(delimiters: [';', ',']),
            requiredColumns: ['email', 'name'],
        );
    }

    public function mapRow(array $row, int $lineNumber): RowMapResult
    {
        return RowMapResult::ok([
            'email' => (string) ($row['email'] ?? ''),
            'name' => (string) ($row['name'] ?? ''),
        ]);
    }
};

$parser = new SpreadsheetParser(logger: $logger);
$result = $parser->parse(ImportSource::fromPath('/path/to/users.csv'), $definition);

Пример: headerless CSV

public function allowHeaderless(): bool
{
    return true;
}

public function mapRow(array $row, int $lineNumber): RowMapResult
{
    $value = trim((string) ($row['column_1'] ?? ''));
    return $value === ''
        ? RowMapResult::error('Строка не содержит значения.', 'raw_value')
        : RowMapResult::ok(['raw_value' => $value, 'line_number' => $lineNumber]);
}

Если allowHeaderless() возвращает true, первая непустая строка считается данными, а заголовки генерируются автоматически (column_1, column_2, ...).

Пример: импорт из контента

$content = "email;name\nuser@example.com;Ivan\n";
$result = $parser->parse(ImportSource::fromContent($content, 'users.csv'), $definition);

Оглавление

统计信息

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

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

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

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固