Php SpreadsheetReader对象创建失败,无异常

Php SpreadsheetReader对象创建失败,无异常,php,mysql,file-upload,spout,Php,Mysql,File Upload,Spout,我正在尝试将我的excel文件上载到MySQL数据库,并使用spoot来完成此操作。这是我的HTML和PHP代码 <!DOCTYPE html> <html> <head> <title>Excel Uploading PHP</title> <link rel="stylesheet" type="text/css" href="https://maxcdn

我正在尝试将我的excel文件上载到MySQL数据库,并使用spoot来完成此操作。这是我的HTML和PHP代码

<!DOCTYPE html>
    <html>
        <head>
            <title>Excel Uploading PHP</title>
            <link rel="stylesheet" type="text/css" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
        </head>
        <body>
            <div class="container">
            <h1>Excel Upload</h1>
                <form method="POST" action="upload_excel.php" enctype="multipart/form-data">
                    <div class="form-group">
                        <label>Upload Excel File</label>
                        <input type="file" name="file" class="form-control">
                    </div>
                    <div class="form-group">
                        <button type="submit" name="Submit" class="btn btn-success">Upload</button>
                    </div>
                </form>
            </div>
        </body>
    </html>

Excel上传PHP
Excel上传
上传Excel文件
上传
下面是PHP代码

<?php

use Box\Spout\Reader\ReaderFactory;
use Box\Spout\Common\Type;

echo 'File Used';

// Include Spout library 
require_once 'Spout/Autoloader/autoload.php';
require 'SpreadsheetReader.php';    
echo 'Require complete';
require('db_connection.php');

// check file name is not empty
if (!empty($_FILES['file']['name'])) {
    // Get File extension eg. 'xlsx' to check file is excel sheet
    $pathinfo = pathinfo($_FILES["file"]["name"]);
    print_r($pathinfo);

    // check file has extension xlsx, xls and also check 
    // file is not empty
if (($pathinfo['extension'] == 'xlsx' || $pathinfo['extension'] == 'xls') 
        && $_FILES['file']['size'] > 0 ) {
        echo 'File validated';
        $inputFileName = 'uploads/'.$_FILES['file']['name'];

        move_uploaded_file($_FILES['file']['tmp_name'], $inputFileName);
        $Reader = new SpreadsheetReader($inputFileName);

        echo $inputFileName;
        try
        {
            $reader = ReaderFactory::create(Type::XLSX);
            echo 'Reader successful';
        }
        catch(Exception $e)
        {
            echo $e->getMessage();
        }
        // Read excel file by using ReadFactory object.

        echo 'opening file';
        // Open file
        $reader->open($inputFileName);
        $count = 1;

        // Number of sheet in excel file
        foreach ($reader->getSheetIterator() as $sheet) {

            // Number of Rows in Excel sheet
            foreach ($sheet->getRowIterator() as $row) {

                // It reads data after header. In the my excel sheet, 
                // header is in the first row. 
                if ($count > 1) { 

                    // Data of excel sheet
                    $data['<column_name>'] = $row[0];
                    $data['<column_name>'] = $row[1];
                    $data['<column_name>'] = $row[2];
                    $data['<column_name>'] = $row[3];
                    $data['<column_name>'] = $row[3];
                    $data['<column_name>'] = $row[3];
                    $data['<column_name>'] = $row[3];
                    $data['<column_name>'] = $row[3];
                    $data['<column_name>'] = $row[3];
                    $data['<column_name>'] = $row[3];

                    $query = "<SQL QUERY GOES HERE>";
                    $result = mysqli_query($conn, $query);

                    print_r(data);

                }
                $count++;
            }
        }

        // Close excel file
        $reader->close();

    } else {

        echo "Please Select Valid Excel File";
    }

} else {

    echo "Please Select Excel File";

}
?>

我已经编写了一些PHP echo来检查程序的流程。该文件可以完美地工作到下一行:
move_-uploaded_-file($_-FILES['file']['tmp_-name'],$inputFileName)
它将文件复制到给定文件夹中,并在尝试创建
SpreadsheetReader
对象时停止。我试图在它周围放置
Try Catch
块来捕获任何异常错误,但也没有捕获任何异常

让我告诉您安装程序的状态:

以上所有内容都托管在
VPS
上,并运行在
ubuntu18.10
上。喷口不是使用composer安装的,我已经从预装的源代码复制了文件

我是否缺少任何必须安装在操作系统上才能解决此问题的软件包?或者这个项目本身缺少什么?我已经搜索了参考文献,但根据文章,这段代码似乎有效。我很困惑,这里的问题在哪里

请有人给我的方向,寻找或至少给我一个工作的Excel MySQL文件上传参考


谢谢

电子表格阅读器
不是一门属于喷口的课程。尝试实例化该类将不起作用,因为您并不“需要”它。这就是你的程序在那里崩溃的原因。你可以去掉这条线,因为我看不到它被使用过

我也看到了这一点:
if($pathinfo['extension']=='xlsx'.\124;$pathinfo['extension']=='xls')


喷咀只支持XLSX文档。因此,如果您将XLS文档传递给它,它将不起作用。

我正在使用通过初始化
电子表格阅读器创建的
$reader
,因此如何删除该行将起作用?除此之外,我还包含
电子表格阅读器
require
语句,但仍然不起作用。要cre如果您使用Spoot阅读一个阅读器,您只需要这一行:
$reader=ReaderFactory::create(Type::XLSX);
。我不知道您创建的
电子表格阅读器是什么,但是Spoot没有它肯定可以工作。请尝试删除这一行:
$reader=new Spreadsheet reader($inputFileName);
,看看这样是否更好(您还可以删除相关的
要求