使用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;
我错过了什么?
提前感谢您的帮助!
答案 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);
}
并且零消失了。