gpt4 book ai didi

php - 在 PHPExcel (Excel2007) 上使用公式的问题

转载 作者:可可西里 更新时间:2023-10-31 22:54:38 26 4
gpt4 key购买 nike

当我尝试使用公式设置单元格的值时,例如:setCellValue('C1', '=A1+B1'),生成的文件没有单元格的计算值。

我有以下脚本:

<?php

require_once '../vendor/autoload.php';
date_default_timezone_set('America/Sao_Paulo');

$objPHPExcel = new PHPExcel();

$objPHPExcel->setActiveSheetIndex(0);
$objPHPExcel->getActiveSheet()->setCellValue('A1', 5)
->setCellValue('B1', 10)
->setCellValue('C1', '=A1+B1');
echo $objPHPExcel->getActiveSheet()->getCell('C1')->getCalculatedValue() . PHP_EOL;

$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
$objWriter->save('a.xlsx');

当我用 libreoffice 打开 a.xlsx 时,单元格 C1 显示字符串“0”。奇怪的是,当我点击单元格时,它实际上显示“=A1+B1”,但不是最终结果。

如何让 PHPExcel 正确处理公式?

最佳答案

我在使用 LibreOffice 5.0.5.2 时遇到了同样的问题。

在 LibreOffice Calc 中更改以下选项对我有用:

  • 转到工具/选项.../LibreOffice Calc/公式
  • 在“文件加载时重新计算”部分、“Excel 2007 及更新版本”中,将值更改为“始终重新计算”

发现于 https://ask.libreoffice.org/en/question/12165/calc-auto-recalc-does-not-work/

关于php - 在 PHPExcel (Excel2007) 上使用公式的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23920238/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com