用java操作excel,jexcelapi

本文介绍了一个使用Java和jxl库创建Excel文件的实用类。该类支持从对象列表生成Excel表格,并能自动处理字符串和数值类型的数据。此外,还提供了求和功能。

这是我自己写的创建Excel的一个类,仅供参考,用的是jxl.jar(见附件)。偷懒总是有方法的,感觉像创建Ext的Grid一样。

接口定义:

 

public void generateExcel(List<?> entities, Column[] columns, String fileName);

 

实现:

package com.yingxia.trms.excel;

import java.io.File;
import java.lang.reflect.Method;
import java.util.List;

import jxl.Workbook;
import jxl.format.Colour;
import jxl.write.Label;
import jxl.write.WritableCell;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;

public class ExcelGeneratorImpl implements ExcelGenerator {

	@Override
	public void generateExcel(List<?> entities, Column[] columns, String fileName) {

		try {
			
			String path = ExcelGeneratorImpl.class.getResource("/").getPath();
			path = path.replace("WEB-INF/classes/", "") + "excel/" + fileName + ".xls";
			
			File file = new File(path);
			if(file.exists()) {
				file.delete();
			}
			
			WritableWorkbook workbook = Workbook.createWorkbook(new File(path));
			WritableSheet sheet = workbook.createSheet("First sheet", 0);
			
			// header
			for (int col = 0; col < columns.length; col++) {
				Label labelHeader = new Label(col, 0, columns[col].getHeader());
				sheet.addCell(labelHeader);
			}
			
			// body
			for (int row = 1; row <= entities.size(); row++) {
				for (int col = 0; col < columns.length; col++) {
					
					String columnName = columns[col].getName();
					Object columnValue = getFieldValue(entities.get(row - 1), columnName);
					
					WritableCell cell = null;
					if(columns[col].getType().equals("string")) {
						cell = new Label(col, row, columnValue.toString());
					} else {
						cell = new jxl.write.Number(col, row, Double.valueOf(columnValue.toString()));
					}
					
					sheet.addCell(cell);
				}
			}
			
			// sum
			for (int col = 0; col < columns.length; col++) {
				
				Column column =  columns[col];
				if(column.isNeedSum() && column.getType().equals("number")) {
					
					Double columnSum = 0.0;
					for (int row = 1; row <= entities.size(); row++) {
						Object fieldValue = getFieldValue(entities.get(row - 1), column.getName());
						columnSum += Double.valueOf(fieldValue.toString());
					}
					
					WritableFont font = new WritableFont(WritableFont.ARIAL);
					font.setColour(Colour.RED);
					font.setBoldStyle(WritableFont.BOLD);
					
					jxl.write.Number number = new jxl.write.Number(col, entities.size() + 1, columnSum, new WritableCellFormat(font));
					sheet.addCell(number);
				}
			}
			
			workbook.write();
			workbook.close();
			
		} catch(Exception ex) {
			ex.printStackTrace();
		}
	}
	
	private Object getFieldValue(Object obj, String fieldName) throws Exception {
		String getMethodName = "get" + fieldName.substring(0, 1).toUpperCase() + fieldName.substring(1);
		Method getMethod = obj.getClass().getMethod(getMethodName);
		return getMethod.invoke(obj);
	}

}

 

这其中用到了一个自定义的Column类

package com.yingxia.trms.excel;

public class Column {

	private String name;
	private String header;
	private String type; // string, number
	private boolean needSum = false; // must be number

	public Column() {
	}

	public Column(String name, String header, String type) {
		super();
		this.name = name;
		this.header = header;
		this.type = type;
	}
	
	public Column(String name, String header, String type, boolean needSum) {
		super();
		this.name = name;
		this.header = header;
		this.type = type;
		this.needSum = needSum;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getHeader() {
		return header;
	}

	public void setHeader(String header) {
		this.header = header;
	}

	public String getType() {
		return type;
	}

	public void setType(String type) {
		this.type = type;
	}

	public boolean isNeedSum() {
		return needSum;
	}

	public void setNeedSum(boolean needSum) {
		this.needSum = needSum;
	}

}
 

 

乐播投屏是一款简单好用、功能强大的专业投屏软件,支持手机投屏电视、手机投电脑、电脑投电视等多种投屏方式。 多端兼容与跨网投屏:支持手机、平板、电脑等多种设备之间的自由组合投屏,且无需连接 WiFi,通过跨屏技术打破网络限制,扫一扫即可投屏。 广泛的应用支持:支持 10000+APP 投屏,包括综合视频、网盘与浏览器、美韩剧、斗鱼、虎牙等直播平台,还能将央视、湖南卫视等各大卫视的直播内容一键投屏。 高清流畅投屏体验:腾讯独家智能音画调校技术,支持 4K 高清画质、240Hz 超高帧率,低延迟不卡顿,能为用户提供更高清、流畅的视觉享受。 会议办公功能强大:拥有全球唯一的 “超级投屏空间”,扫码即投,无需安装。支持多人共享投屏、远程协作批注,PPT、Excel、视频等文件都能流畅展示,还具备企业级安全加密,保障会议资料不泄露。 多人互动功能:支持多人投屏,邀请好友加入投屏互动,远程也可加入。同时具备一屏多显、语音互动功能,支持多人连麦,实时语音交流。 文件支持全面:支持 PPT、PDF、Word、Excel 等办公文件,以及视频、图片等多种类型文件的投屏,还支持网盘直投,无需下载和转格式。 特色功能丰富:投屏时可同步录制投屏画面,部分版本还支持通过触控屏或电视端外接鼠标反控电脑,以及在投屏过程中用画笔实时标注等功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值