我们经常在用jxl 生成Excel 报表的时候最郁闷的估计就是用代码画Excel 格式,碰到构造复杂的Excel要画好定义的格式还是得花些时间,前段时间因为项目需要用到了Aspose 组件,挺好用,标记一下.
先预览一下用 Aspose.cells 导出的Excel:
实现步骤
1. 定义Excel 导出模版,如图,根据需求定义行,列,格式的Excel样式,接下来就是怎么用这个模版填充数据生成Excel数据报表,至于模版中的变量表达式,看下面demo 代码会明白怎么填充.
3.在工程里利用Aspose.cell 操作Excel模版,填充数据,生成Excel 报表
//操作Aspose.cell
public class Test {
public static void main(String[] args) {
try{
Workbook wb = new Workbook("D:/test.xls");//打开模版文件
WorkbookDesigner designer = new WorkbookDesigner();//加载设计器
designer.setWorkbook(wb);
designer.setDataSource("uname","李四");//设置变量数据
designer.setDataSource("Score", getScore());//设置类对象数据
designer.process();
wb.save("E:/fex/test.xls");//生成报表
}catch(Exception ex){
ex.printStackTrace();
}
}
public static List<Score> getScore() {
List<Score> scores = new ArrayList<Score>();
for( int i = 0 ; i < 3 ; i++){
Score score = new Score();
String str = "";
if(i == 0 )
str = "语文";
if(i == 1)
str = "数学";
if(i == 2)
str = "体育";
score.setSname(str);
score.setSscore(100);
score.setFscore(55);
score.setTscore(85);
scores.add(score);
}
return scores;
}
}
//成绩类
public class Score {
String sname;
int sscore;
int tscore;
int fscore;
public int getFscore() {
return fscore;
}
public void setFscore(int fscore) {
this.fscore = fscore;
}
public int getTscore() {
return tscore;
}
public void setTscore(int tscore) {
this.tscore = tscore;
}
public String getSname() {
return sname;
}
public void setSname(String sname) {
this.sname = sname;
}
public int getSscore() {
return sscore;
}
public void setSscore(int sscore) {
this.sscore = sscore;
}
}
4. 表达式,动态公式说明
&= : 标致变量
&=$uname :变量绑定
&=Score.sname :类对象集合变量绑定
&=&= :Excel动态公式引用
&=&=C{r}*E{r}:{r} 对应当前行,
在定义模版里的动态计算公式的时候,公式是和Excel里面我们用到的一样,只不过有的需要动态变量.
如在指定列求和或做统计算的时候,要加减行,这时的做法和Excel里动态公式一样,例如上面的例子,在求一模各科总分的时候我们要的结果是:
SUM(C4:C6)的值,且在C7 显示, 在这里因为模版是动态加载,所以结束行不确定,所有就得用上面说的{r}公式,这里引用动态公式就写成了这样:
&=&=Sum(OFFSET(C$3,1,):OFFSET(C{r},-1,)) , C列第四行到C列第N-1行的和.
Aspose 这个插件很强大,还有蛮多东西,有兴趣可以搞点文档,下个包,亲手跑一下.
·