import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import jxl.Workbook;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
/**
* 创建xls文件并输出
* @author gyl
*
*/
public class SimpleExcel {
public static void createExcel(OutputStream os,ArrayList<ArrayList<Object>> list)
throws WriteException,IOException{
//创建工作薄
WritableWorkbook workbook = Workbook.createWorkbook(os);
//创建新的一页
WritableSheet sheet = workbook.createSheet("Sheet1",0);
if(list!=null&&list.size()>0){
int columnBestWidth[]=new int[list.get(0).size()]; //保存最佳列宽数据的数组
for(int i=0;i<list.size();i++){
for(int j=0;j<list.get(i).size();j++){
//创建要显示的内容,创建一个单元格,第一个参数为列坐标,第二个参数为行坐标,第三个参数为内容
String str = (list.get(i).get(j)+"").replace("null", "");
sheet.addCell(new Label(j,i,str));
int width = str.length()+getChineseNum(str);
if(columnBestWidth[j]<width){
columnBestWidth[j]=width+2;///求取到目前为止的最佳列宽
}
}
}
for(int i=0;i<columnBestWidth.length;i++){ ///设置每列宽
sheet.setColumnView(i, columnBestWidth[i]);
}
}
workbook.write();
workbook.close();
os.close();
}
public static int getChineseNum(String context){ ///统计context中是汉字的个数
int lenOfChinese=0;
Pattern p = Pattern.compile("[\u4e00-\u9fa5]"); //汉字的Unicode编码范围
Matcher m = p.matcher(context);
while(m.find()){
lenOfChinese++;
}
return lenOfChinese;
}
}
strust2Action部分:
import java.io.IOException;
import java.io.OutputStream;
import java.io.UnsupportedEncodingException;
import java.util.ArrayList;
import java.util.Map;
import javax.servlet.ServletContext;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import jxl.write.WriteException;
import org.apache.commons.lang.StringUtils;
import org.apache.struts2.ServletActionContext;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.util.Assert;
import com.ewash.common.util.SimpleExcel;
/**
* xls下载
* @param list
*/
public void downloadExcel(ArrayList<ArrayList<Object>> list,String fileName){
try {
OutputStream os = getResponse().getOutputStream();
fileName = new String(fileName.getBytes("UTF-8"),"ISO-8859-1");
getResponse().setHeader("Content-Disposition","attachment;filename="+fileName+".xls");
getResponse().setContentType("application/msexcel");
SimpleExcel.createExcel(os, list);
} catch (IOException e) {
e.printStackTrace();
} catch (WriteException e) {
e.printStackTrace();
}
}
/**
* 获取 application 对象.
* @return ServletContext
*/
public ServletContext getApplication() {
return ServletActionContext.getServletContext();
}
/**
* 获取请求对象.
* @return HttpServletRequest
*/
public HttpServletRequest getRequest() {
return ServletActionContext.getRequest();
}
/**
* 获取请求对象.
* @return HttpServletRequest
*/
public HttpServletResponse getResponse() {
return ServletActionContext.getResponse();
}
/**
* 获得传递参数
* @param str
* @return String
*/
public String getParameter(String str) {
return getRequest().getParameter(str);
}
分享到:
相关推荐
jxl导出excel加水印 WritableWorkbook、WritableSheet、WritableCellFormat
jxl导出excel 完整例子工程jxl导出excel 完整例子工程jxl导出excel 完整例子工程 jxl导出excel 完整例子工程jxl导出excel 完整例子工程jxl导出excel 完整例子工程
利用JXL技术支持模板和非模板的表格导出
NULL 博文链接:https://duanfei.iteye.com/blog/1807694
jxl数据导入导出jxl数据导入导出jxl数据导入导出 jxl数据导入导出jxl数据导入导出jxl数据导入导出
jxl导出文件:将list导出到excel文件中,有模板无模板两种方式,只支持excel2003
jxl导出excel工具类,封装好了的,实现传递任意集合自动导出excel
java jxl导出excel文件前两天公司的同事用java jxl写了一段导出excel的代码,值得学习,现提供代码
使用jxl导出Excel表的好例子 导出excel表的例子
jxl导出Excel基础,非常有用的一个东西,漫漫看
java jxl 导出功能,支持多个sheet 页导出
用jxl导出excel报表的简单应用,帮助理解
jxl导入导出excel 详细的描述了如何使用jxl导入导出excel。
导入导出、合并单元格处理代码示例 jar包解决导出Excel 出现的问题:Warning: Maximum number of format records exceeded. Using default format.
Android使用jxl快速导出excel表
JXLTestServlet java是导出的servlet 同样的 包含了上次的所有功能 ">jxl实现文件导出 上次只是简单的导出 没有实现excel样式 这次实现了样式 在com test newtest包中实现了样式功能 JXLExcelUtils java封装了excel...
很简单 没有任何难度 应用完整的jar包完整自定义下载功能 绝不坑爹
jxl java excel export jxl数据导出,完整代码附带jar
利用jxl实现数据库内容导出到Excel表格中,压缩文件里包括jxl.jar包、例子源代码、txt文档代码
这是一个jxl声称excel的示例,及jxl的文档