Aspose.cells 用excel 模版 生成报表 Java


我们经常在用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 这个插件很强大,还有蛮多东西,有兴趣可以搞点文档,下个包,亲手跑一下.

   

  

·


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值