您的位置:首页 > 编程语言 > Java开发

java 解析excle和生成excle文档

2016-05-17 23:33 357 查看
只贴出关键代码,其他一概论之

java解析excle文件:

Workbook book = Workbook.getWorkbook(new File(fileName)) ; //filename为需要解析的excle
Sheet sheet = book.getSheet(0);
int rows = sheet.getRows();
int celllength = sheet.getRow(0).length;//只获取标题这么多列的数据,其他的就不管了
List<List> all_data = new ArrayList();
for(int i = 1; i < rows; i++) {   //i=1,是因为需要将第一行标题去掉
List data = new ArrayList();
Cell [] cell = sheet.getRow(i);
for(int j=0; j<celllength; j++) {
String content="";
try{
//将第i行,第j列的数据保存
content=sheet.getCell(j, i).getContents();
}catch(Exception e){
content="";
}

data.add(content);
}
//最后所有的数据都保存在all_data里面啦
all_data.add(data);
}


一般的操作需要上传再解析,曾经傻傻的以为可以上传的时候就直接解析,才发现大错特错了。
真实的基本流程为,excle上传到本地,得到保存在本地的路劲,读取该路径的excle文件,。

生成excle文件,并下载
response.setContentType("application/vnd.ms-excel;charset=UTF-8");
String filename = new String("工资模板.xls".getBytes("gb2312"),"ISO8859-1");
response.addHeader("Content-Disposition", "filename=" + filename);
OutputStream os=response.getOutputStream();
//创建工作薄
WritableWorkbook workbook = Workbook.createWorkbook(os);
WritableSheet sheet = workbook.createSheet("First Sheet",0);//一个excle文件可以有多个sheet

//创建标题,假设只有2列
Label l = new Label(0,0,"员工编号");
sheet.addCell(l);
l = new Label(1,0,"姓名");
sheet.addCell(l);

//开始添加数据了
l = new Label(0,1,"01");
l = new Label(1,1,"张三");
sheet.addCell(l);

l = new Label(0,2,"02");
l = new Label(1,2,"李四");
sheet.addCell(l);

//直接下载,如果是需要写在某个位置的话,则另当别论
workbook.write();
workbook.close();
os.flush();
os.close();


说明,Label里面的参数为 Label(列,行,内容)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java 上传 excle