55 lines
2.6 KiB
Markdown
55 lines
2.6 KiB
Markdown
|
# OpenSpout
|
||
|
|
||
|
[data:image/s3,"s3://crabby-images/9efeb/9efebcb13019939f94ab840d8716d1b4633c56c6" alt="Latest Stable Version"](https://packagist.org/packages/openspout/openspout)
|
||
|
[data:image/s3,"s3://crabby-images/9dd69/9dd69d83324228a2d0a2e930c9c50086a7820e4c" alt="Build Status"](https://github.com/openspout/openspout/actions/workflows/ci.yml)
|
||
|
[data:image/s3,"s3://crabby-images/e0660/e06605112ffec3a76479f2956c16249d9421f428" alt="Code Coverage"](https://codecov.io/gh/openspout/openspout?branch=main)
|
||
|
[data:image/s3,"s3://crabby-images/1f4c5/1f4c5803399782271cd467f44231134cec562366" alt="Total Downloads"](https://packagist.org/packages/openspout/openspout)
|
||
|
|
||
|
OpenSpout is a community driven fork of `box/spout`, a PHP library to read and write spreadsheet files (CSV, XLSX and ODS), in a fast and scalable way.
|
||
|
Unlike other file readers or writers, it is capable of processing very large files, while keeping the memory usage really low (less than 3MB).
|
||
|
|
||
|
## Documentation
|
||
|
|
||
|
Documentation can be found at [https://openspout.readthedocs.io/en/latest/](https://openspout.readthedocs.io/en/latest/).
|
||
|
|
||
|
## Requirements
|
||
|
|
||
|
* PHP version 7.3 or higher
|
||
|
* PHP extension `php_zip` enabled
|
||
|
* PHP extension `php_xmlreader` enabled
|
||
|
|
||
|
## Upgrade from `box/spout`
|
||
|
|
||
|
1. Replace `box/spout` with `openspout/openspout` in your `composer.json`
|
||
|
2. Replace `Box\Spout` with `OpenSpout` in your code
|
||
|
|
||
|
## Upgrade guide
|
||
|
|
||
|
Version 3 introduced new functionality but also some breaking changes. If you want to upgrade your Spout codebase from version 2 please consult the [Upgrade guide](UPGRADE-3.0.md).
|
||
|
|
||
|
## Running tests
|
||
|
|
||
|
The `main` branch includes unit, functional and performance tests.
|
||
|
If you just want to check that everything is working as expected, executing the unit and functional tests is enough.
|
||
|
|
||
|
* `phpunit` - runs unit and functional tests
|
||
|
* `phpunit --group perf-tests` - only runs the performance tests
|
||
|
|
||
|
For information, the performance tests take about 10 minutes to run (processing 1 million rows files is not a quick thing).
|
||
|
|
||
|
> Performance tests status: [data:image/s3,"s3://crabby-images/b71b9/b71b9e135a5a8bf0c4462d391a6df114de19f1d6" alt="Build Status"](https://travis-ci.org/box/spout)
|
||
|
|
||
|
## Copyright and License
|
||
|
|
||
|
This is a fork of Box's Spout library: https://github.com/box/spout
|
||
|
|
||
|
Code until and directly descending from commit [`cc42c1d`](https://github.com/openspout/openspout/commit/cc42c1d29fc5d29f07caeace99bd29dbb6d7c2f8)
|
||
|
is copyright of _Box, Inc._ and licensed under the Apache License, Version 2.0:
|
||
|
|
||
|
https://github.com/openspout/openspout/blob/cc42c1d29fc5d29f07caeace99bd29dbb6d7c2f8/LICENSE
|
||
|
|
||
|
Code created, edited and released after the commit mentioned above
|
||
|
is copyright of _openspout_ Github organization and licensed under MIT License.
|
||
|
|
||
|
https://github.com/openspout/openspout/blob/main/LICENSE
|