一、介绍
    用纯 php 编写的库,它提供了一组类,允许您读取和写入不同的电子表格文件格式
    支持格式
    环境要求

    1. php 5.6 及以上
    2. php_zip 支持并启用
    3. php_xml 支持并启用
    4. php_gd2 支持并启用

    安装
    > composer require phpoffice/phpspreadsheet
    使用

    1. require 'vendor/autoload.php';
    2. use PhpOffice\PhpSpreadsheet\Spreadsheet;
    3. use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
    4. $spreadsheet = new Spreadsheet();
    5. $sheet = $spreadsheet->getActiveSheet();
    6. $sheet->setCellValue('A1', 'Hello World !');
    7. $writer = new Xlsx($spreadsheet);
    8. $writer->save('hello world.xlsx');

    实例
    包中带了实例代码,位置 vendor/phpoffice/phpspreadsheet/samples 下

    1. > php -S localhost:8000 -t vendor/phpoffice/phpspreadsheet/samples

    二、读取
    无需关心文件类型加载,用到了 IOFactory

    1. // 文件路径
    2. $inputFileName = './sampleData/example1.xls';
    3. $spreadsheet = \PhpOffice\PhpSpreadsheet\IOFactory::load($inputFileName);

    注意:
    这不是加载文件的最有效方法, 并且它缺乏在将文件实际读入 Spreadsheet 对象之前以任何方式配置加载器的灵活性。
    知道文件类型,可以自己决定使用哪种读取器

    1. // 文件路径
    2. $inputFileName = './sampleData/example1.xls';
    3. /** 创建读取器 **/
    4. $reader = new \PhpOffice\PhpSpreadsheet\Reader\Xls();
    5. // $reader = new \PhpOffice\PhpSpreadsheet\Reader\Xlsx();
    6. // $reader = new \PhpOffice\PhpSpreadsheet\Reader\Xml();
    7. // $reader = new \PhpOffice\PhpSpreadsheet\Reader\Ods();
    8. // $reader = new \PhpOffice\PhpSpreadsheet\Reader\Slk();
    9. // $reader = new \PhpOffice\PhpSpreadsheet\Reader\Gnumeric();
    10. // $reader = new \PhpOffice\PhpSpreadsheet\Reader\Csv();
    11. $spreadsheet = $reader->load($inputFileName);

    当只要读取数据,不要格式时,实例读取器中 readDataOnly 属性,如下

    1. $inputFileType = 'Xls';
    2. $inputFileName = './sampleData/example1.xls';
    3. $reader = \PhpOffice\PhpSpreadsheet\IOFactory::createReader($inputFileType);
    4. /** 只要数据 **/
    5. $reader->setReadDataOnly(true);
    6. $spreadsheet = $reader->load($inputFileName);

    注意:csv 读取器没有这个属性
    多个文件合并为一个对象

    1. $inputFileType = 'Csv';
    2. $inputFileNames = [
    3. './sampleData/example1.csv',
    4. './sampleData/example2.csv'
    5. './sampleData/example3.csv'
    6. ];
    7. $reader = \PhpOffice\PhpSpreadsheet\IOFactory::createReader($inputFileType);
    8. /** 拿到第一个 **/
    9. $inputFileName = array_shift($inputFileNames);
    10. $spreadsheet = $reader->load($inputFileName);
    11. $spreadsheet->getActiveSheet()
    12. ->setTitle(pathinfo($inputFileName,PATHINFO_BASENAME));
    13. /** 循环读取 **/
    14. foreach($inputFileNames as $sheet => $inputFileName) {
    15. /** 重新设置工作表索引 **/
    16. $reader->setSheetIndex($sheet+1);
    17. /** 把文件当做一个新的工作表载入 **/
    18. $reader->loadIntoExisting($inputFileName,$spreadsheet);
    19. /** 设置工作表标题 **/
    20. $spreadsheet->getActiveSheet()
    21. ->setTitle(pathinfo($inputFileName,PATHINFO_BASENAME));
    22. }

    注意:对多个工作表使用相同的工作表索引不会将文件附加到同一工作表中,而是覆盖先前加载的结果。您无法将多个 CSV 文件加载到同一工作表中。
    转为数组
    文件最后会载入到一个对象中,我称为 spreadsheet 工作表对象,这个对象中存放着所以工作表集合的信息(数据信息和格式信息、工作表信息等)

    1. $spreadsheet = PhpOffice\PhpSpreadsheet\IOFactory::load("new.xls");
    2. $data = $spreadsheet
    3. ->getSheet(0) // 指定第一个工作表为当前
    4. ->toArray(); // 转为数组
    5. // 或者得到全部工作表的数据数组
    6. $cells=array();
    7. // 工作表对象有迭代器实现
    8. foreach ( $spreadsheet->getWorksheetIterator() as $data ) {
    9. $cells = $data->toArray();
    10. }

    结语
    PhpSpreadsheet 是非常不错的 php 的电子表格处理工具类,后续有时间在补上写入和导出。