首页 > 解决方案 > 为什么无法通过 PhpOffice\PhpSpreadsheet 读取 csv 文件?

问题描述

我正在使用 PhpOffice\PhpSpreadsheet 读取 csv 文件,例如:

$reader = \PhpOffice\PhpSpreadsheet\IOFactory::createReaderForFile($file);
$reader->setReadDataOnly(true);
$spreadsheet = $reader->load($file);

它错误:Warning: mime_content_type(): Can only process string or stream arguments

但它适用于 xlsx 文件。

我尝试使用 PhpOffice\PhpSpreadsheet\Reader\Csv 但这是同样的错误。我尝试转储 $file,我看到 mimeType 是text/csv,但是当 $file->getMimeType() 是 return 时text/plain。这使我无法验证上传文件(我只允许用户上传 xlsx/csv 文件)。我认为这可能导致错误无法读取 csv 文件?

编辑:这是我的错。load()将参数作为字符串接收,但我传递了 Symfony\Component\HttpFoundation\File\UploadFile (因为它适用于 xlsx 文件)。所以改成$file$file->getPathName()效果很好。但是使用验证文件,我想我必须接受文本/纯文本,有人知道吗?

标签: phpphpoffice-phpspreadsheet

解决方案


您可以使用该方法检查文件的 MIME 类型$file->getClientMimeType()。这将为您提供您正在寻找的“text/csv”字符串。


推荐阅读