- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在我的 PHPExcel 中使用 getCalculatedValue() 来读取 34 个 Excel 文件。不幸的是,有些用户将 i:\drive\test[month.xls]$C$1 放入单元格中,导致 PHPExcel 无法读取和存储 #REF!在 mysql 中。
我知道 getCalculatedValue() 会读取单元格中的公式,但是链接呢?另外,在Excel文件中找到的链接是外部链接,我无法访问。
虽然单元格包含指向另一个工作表的链接,但单元格本身显示了一些值。最好的解决方案是复制所有并粘贴值。但是为此目的打开 34 个 Excel 文件似乎不切实际。
感谢有人能启发我。
谢谢。
最佳答案
PHPExcel最新的SVN代码遇到引用外部工作簿会抛出异常。您可以将 getCalculatedValue() 调用包装在 try/catch block 中,如果抛出此异常,请使用 getOldCalculatedValue() 检索 MS Excel 本身上次计算此单元格值时的结果。
#REF! response 可能是来自公式的完全有效的响应,因此仅仅捕获它是不够的,这就是在这种特定情况下抛出异常的原因。
请注意,这不能保证 - 可以禁用 Excel 中的自动计算,或者引用的外部工作簿在您正在阅读的工作簿被保存后被修改 - 在这两种情况下,getOldCalculatedValue() 可能会返回一个错误的结果,你无法知道是否是这种情况......但它通常非常准确。 SVN 代码修改正是出于这个原因,当时我在 12 月遇到与我合作的客户的相同情况;代码将包含在 PHPExcel 的 1.7.7 生产版本中,该版本将于本周末发布。
编辑
try {
$calculatedValue = $objPHPExcel->getActiveSheet()->getCell('A1')->getCalculatedValue();
} catch (Exception $e) {
$calculatedValue = $objPHPExcel->getActiveSheet()->getCell('A1')->getOldCalculatedValue();
}
关于PHPExcel getCalculatedValue() 导致#REF,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9164507/
我有一个包含 6 张纸的 .xlsx 文件,我用它加载 $objPHPExcel = PHPExcel_IOFactory::load('./FINAL SEB.xlsx'); 当我想从单元格中获取计
我在我的 PHPExcel 中使用 getCalculatedValue() 来读取 34 个 Excel 文件。不幸的是,有些用户将 i:\drive\test[month.xls]$C$1 放入单
我在我的 PHPExcel 中使用 getCalculatedValue() 来读取 34 个 Excel 文件。不幸的是,有些用户将 i:\drive\test[month.xls]$C$1 放入单
谁能帮我处理 phpExcel 代码: 此代码: $objPHPExcel->getActiveSheet()->getCell("AF19")->getCalculatedValue(); $obj
我是一名优秀的程序员,十分优秀!