首页 > 解决方案 > 盒子/喷口没有写满行

问题描述

我正在尝试使用 Box/Spout 将数据写入 Excel 工作表,使用写入器将数组传递给addrow()函数,但是当 Excel 文件完成时,工作表上缺少数据列......

该数组正是我需要的数据,我var_dump()用它来显示数据。数据最初来自 mysql 查询,所以我认为直接从mysqli_fetch_assoc函数添加行会起作用。遇到这个问题后,我创建了一个名为 row 的变量$newRow并将其声明为一个数组,其中包含 mysql fetch 数据。这仍然没有奏效。下面的代码来解释我的困惑......

这是我要添加的行的 var_dump:

var_dump($newRow);
array(29) { 
[0]=> string(14) "X" 
[1]=> string(6) "X" 
[2]=> string(4) "X" 
[3]=> string(9) "X" 
[4]=> string(2) "X" 
[5]=> string(1) "X" 
[6]=> string(1) "X" 
[7]=> string(8) "X" 
[8]=> string(0) "" 
[9]=> string(8) "X" 
[10]=> string(16) "X" 
[11]=> string(16) "X" 
[12]=> string(0) "X" 
[14]=> string(7) "X" 
[15]=> string(2) "X" 
[16]=> string(2) "X" 
[17]=> string(1) "X" 
[18]=> string(2) "X" 
[19]=> string(2) "X" 
[20]=> string(2) "X" 
[21]=> string(15) "X" 
[22]=> string(9) "X" 
[23]=> string(2) "X" 
[24]=> string(5) "X" 
[25]=> string(16) "Y" 
[26]=> string(9) "Y" 
[27]=> string(2) "Y" 
[28]=> string(5) "Y" 
}

出于隐私原因,我需要用 X 和 Y 替换真实数据。请理解,这样做我用这些字母替换了真实存在的数据。我会包括我使用的 mysql 查询,但它是不必要的,因为它清楚地成功提取了信息......

下一行是:

$writer->addrow($newRow);

请记住,代码看起来完全像这样:

var_dump($newRow);
echo "<br/><br/>";
$writer->addrow($newRow);

$newRow并且之前的$writer->addrow功能没有变化。

不幸的是,excel工作表另存为

|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|

在一行中与应该是什么:

|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|X|Y|Y|Y|Y|

我已经为此困惑了几个小时,还没有找到解决方案。我希望我的问题有意义,并且非常感谢任何建议。

标签: phparraysexcelspout

解决方案


尝试这个

$writer->addRow(WriterEntityFactory::createRowFromArray($newRow));

推荐阅读