Vit*_*ano 3 php csv excel phpexcel xlsb
我正在尝试将*.xlsb文件转换为php array或*.csv文件(或至少*.xls)。我尝试使用PHPExcel,但它似乎无法识别此文件中的内容。
我注意到,您可以将*.xlsb文件重命名为*.zip文件,然后使用命令行解压缩它unzip *.zip。在此之后,您将获得下一个包含sheet1.bin文件的文件夹:
看起来这个文件应该包含 Excel 单元格值,但我仍然无法使用PHPExcel. 有人可以帮我解析*.xlsb文件并从中获取信息吗?或者也许可以解析这个sheet1.bin文件?
PHPExcel 不支持 XLSB 文件。XLSB 文件格式是 zip 存档,与 XLSX 相同,但存档中的大多数文件是二进制文件。二进制文件不容易解析。
支持 XLSB 文件的 PHP Excel 库是EasyXLS。您可以从这里下载库。
将 XLSB 转换为 PHP 数组
//Code for reading xlsb file
$workbook = new COM("EasyXLS.ExcelDocument");
$workbook->easy_LoadXLSBFile("file.xlsb");
//Code for building the php array
$xlsTable = $workbook->easy_getSheetAt(0)->easy_getExcelTable();
for ($row=0; $row<$xlsTable->RowCount(); $row++)
{
for ($column=0; $column<$xlsTable->ColumnCount(); $column++)
{
$value = $xlsTable->easy_getCell($row, $column)->getValue();
//transfer $value into your array
}
}
Run Code Online (Sandbox Code Playgroud)
或者
//Code for reading xlsb file
$workbook = new COM("EasyXLS.ExcelDocument");
$rows = $workbook->easy_ReadXLSBActiveSheet_AsList("file.xlsb");
//Code for building the php array
for ($rowIndex=0; $rowIndex<$rows->size(); $rowIndex++)
{
$row = $rows->elementAt($rowIndex);
for ($cellIndex=0; $cellIndex<$row->size(); $cellIndex++)
{
$value = $row->elementAt($cellIndex);
//transfer $value into your array
}
}
Run Code Online (Sandbox Code Playgroud)
将 XLSB 转换为 CSV
//Code for reading xlsb file
$workbook = new COM("EasyXLS.ExcelDocument");
$workbook->easy_LoadXLSBFile("file.xlsb");
//Code for converting to CSV
$workbook->easy_WriteCSVFile("file.csv", $workbook->easy_getSheetAt(0)->getSheetName());
Run Code Online (Sandbox Code Playgroud)
将 XLSB 转换为 XLS
//Code for reading xlsb file
$workbook = new COM("EasyXLS.ExcelDocument");
$workbook->easy_LoadXLSBFile("file.xlsb");
//Code for converting to XLS
$workbook->easy_WriteXLSFile("file.xls");
Run Code Online (Sandbox Code Playgroud)