PHPExcel在范围公式中填充0值

时间:2014-01-03 11:31:42

标签: phpexcel

使用PHPExcel 1.7.9,我只是在将文件发送给用户之前阅读Excel模板并在特定单元格中填充值。

模板中包含范围公式,用于计算列和行的总计。麻烦的是,无论如何,使用Writer将公式值设置为0而不是保持空白(这是实际的Excel行为)。

我尝试使用$objWriter->setPreCalculateFormulas(false);方法,但无济于事。

当然可以重写所有公式并应用条件来规避问题,但这并不理想,而且看起来相当矫枉过正。

仅仅是为了获取信息,这是我的作家代码:

$objWriter = new PHPExcel_Writer_Excel2007($obj);
$objWriter->setPreCalculateFormulas(false);
PHPExcel_Calculation::getInstance($obj)->clearCalculationCache();
$objWriter->save('php://output');
exit;

我错过了什么?

提前感谢您的帮助!

1 个答案:

答案 0 :(得分:1)

我使用private Drawable buildCounterDrawable(int count, int backgroundImageId) { LayoutInflater inflater = LayoutInflater.from(this); View view = inflater.inflate(R.layout.counter_menuitem_layout, null); view.setBackgroundResource(backgroundImageId); if (count == 0) { View counterTextPanel = view.findViewById(R.id.counterValuePanel); counterTextPanel.setVisibility(View.GONE); } else { TextView textView = (TextView) view.findViewById(R.id.count); textView.setText("" + count); } view.measure( View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED), View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED)); view.layout(0, 0, view.getMeasuredWidth(), view.getMeasuredHeight()); view.setDrawingCacheEnabled(true); view.setDrawingCacheQuality(View.DRAWING_CACHE_QUALITY_HIGH); Bitmap bitmap = Bitmap.createBitmap(view.getDrawingCache()); view.setDrawingCacheEnabled(false); return new BitmapDrawable(getResources(), bitmap); } 并且零消失了。