mirror of
https://github.com/moodle/moodle.git
synced 2025-01-18 22:08:20 +01:00
55 lines
2.6 KiB
Markdown
55 lines
2.6 KiB
Markdown
# OpenSpout
|
|
|
|
[![Latest Stable Version](https://poser.pugx.org/openspout/openspout/v/stable)](https://packagist.org/packages/openspout/openspout)
|
|
[![Build Status](https://github.com/openspout/openspout/actions/workflows/ci.yml/badge.svg)](https://github.com/openspout/openspout/actions/workflows/ci.yml)
|
|
[![Code Coverage](https://codecov.io/gh/openspout/openspout/coverage.svg?branch=main)](https://codecov.io/gh/openspout/openspout?branch=main)
|
|
[![Total Downloads](https://poser.pugx.org/openspout/openspout/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: [![Build Status](https://travis-ci.org/box/spout.svg?branch=perf-tests)](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
|