在java中使用jxl操作excel
2017-04-21 19:46
706 查看
jxl是一个韩国人写的Java操作excel的工具, 在java的开源世界中,有两套比较有影响的API可供使用,一个是POI,一个是jExcelAPI(即jxl)。jxl功能相对POI比较弱一点。
但jExcelAPI对中文支持非常好,API是纯Java的, 不依赖Windows系统,即使运行在Linux下,也同样能够正确的处理Excel文件。
需要补充说明的是,jxl对图形和图表的支持很有限,而且 仅仅识别PNG格式的图片。
下面就是我对jxl一些常见操作进行介绍,比如读取excel,新建excel合并单元格等待操作。
并根据网络上搜集到的资料对jxl和POI进行一次简单的比较。
附jxl.jar下载地址:http://sourceforge.net/projects/jexcelapi/files/jexcelapi/
工作表(sheet):在excel中对应于如下截图中的红色圈中部分
单元格对象:在excel中对应于如下截图中的红色圈中部分
plain copy
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.read.biff.BiffException;
public class ReadExcel {
public static void main(String[] args) throws BiffException, IOException {
// 1、构造excel文件输入流对象
String sFilePath = "D:/1.xls";
InputStream is = new FileInputStream(sFilePath);
// 2、声明工作簿对象
Workbook rwb = Workbook.getWorkbook(is);
// 3、获得工作簿的个数,对应于一个excel中的工作表个数
rwb.getNumberOfSheets();
Sheet oFirstSheet = rwb.getSheet(0);// 使用索引形式获取第一个工作表,也可以使用rwb.getSheet(sheetName);其中sheetName表示的是工作表的名称
// System.out.println("工作表名称:" + oFirstSheet.getName());
int rows = oFirstSheet.getRows();//获取工作表中的总行数
int columns = oFirstSheet.getColumns();//获取工作表中的总列数
for (int i = 0; i < rows; i++) {
for (int j = 0; j < columns; j++) {
Cell oCell= oFirstSheet.getCell(j,i);//需要注意的是这里的getCell方法的参数,第一个是指定第几列,第二个参数才是指定第几行
System.out.println(oCell.getContents()+"\r\n");
}
}
}
}
plain copy
import java.io.File;
import java.io.IOException;
import jxl.Workbook;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;
public class WriteExcel {
public static void main(String[] args) throws IOException,
RowsExceededException, WriteException {
// 1、创建工作簿(WritableWorkbook)对象,打开excel文件,若文件不存在,则创建文件
WritableWorkbook writeBook = Workbook.createWorkbook(new File(
"D://write.xls"));
// 2、新建工作表(sheet)对象,并声明其属于第几页
WritableSheet firstSheet = writeBook.createSheet("第一个工作簿", 1);// 第一个参数为工作簿的名称,第二个参数为页数
WritableSheet secondSheet = writeBook.createSheet("第二个工作簿", 0);
// 3、创建单元格(Label)对象,
Label label1 = new Label(1, 2, "test1");// 第一个参数指定单元格的列数、第二个参数指定单元格的行数,第三个指定写的字符串内容
firstSheet.addCell(label1);
Label label2 = new Label(1, 2, "test2");
secondSheet.addCell(label2);
// 4、打开流,开始写文件
writeBook.write();
// 5、关闭流
writeBook.close();
}
}
plain copy
import java.io.File;
import java.io.IOException;
import jxl.Workbook;
import jxl.read.biff.BiffException;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;
public class MergeCell {
public static void main(String[] args) throws IOException,
RowsExceededException, WriteException, BiffException {
// 1、创建WritableWorkbook对象
File file = new File("D:/write.xls");
WritableWorkbook oWritableBK = Workbook.createWorkbook(file);
// 2、创建WritableSheet对象
WritableSheet oWritableSheet = oWritableBK.createSheet("testsheet1", 0);
// 3、添加单元格
Label label1 = new Label(0, 0, "test1");
oWritableSheet.addCell(label1);
Label label30 = new Label(3, 1, "我是合并后的单元格!");
oWritableSheet.addCell(label30);
//4、 合并单元格
oWritableSheet.mergeCells(3,1, 9, 1);// 参数说明,前两个参数为待合并的起始单元格位置,后两个参数用来指定结束单元格位置(列和行)
oWritableBK.write();
oWritableBK.close();
}
}
POI对公式的支持比较好,jxl对公式的支持不如POI。所以财务软件用POI较好
多少数据量时出现内存溢出:
使用POI:运行到2800条左右就报内存溢出,使用jxl到3000条左右报内存溢出
读取excel速率:POI优于jxl
插入数据速率:jxl优于POI
1、准备:
将commons-fileupload-1.1.zip和commons-io-1.1.zip复制到"\WEB-INF\lib"目录下
2、首先是Servlet:FileUpload.java
3、其次是html:Uploadfile.html
4、最后是配置web.xml
首先运行html,servlet处理上传请求
网上相关的例子比较多,这里只给出最简单的一个,使用commons-fileupload组件完成上传。首先你需要下载组件,按说从官网上下载文件应该就可以了,不过貌似最新的这个少了一个jar包,所以我往网盘里传了一份,大家自行下载:http://u.115.com/file/f4694e2ffc http://u.115.com/file/f4e87888d0 ,把这俩文件放到工程WEN-INF的lib目录下。
首先建立一个Servlet:UploadServlet.java:
然后是web.xml文件:
上传文件的页面:upload.jsp
更多内容可以参考这里:http://www.blogjava.net/freeman1984/archive/2007/09/28/149358.html
但jExcelAPI对中文支持非常好,API是纯Java的, 不依赖Windows系统,即使运行在Linux下,也同样能够正确的处理Excel文件。
需要补充说明的是,jxl对图形和图表的支持很有限,而且 仅仅识别PNG格式的图片。
下面就是我对jxl一些常见操作进行介绍,比如读取excel,新建excel合并单元格等待操作。
并根据网络上搜集到的资料对jxl和POI进行一次简单的比较。
1、下载类库包jxl.jar
下载好jxl.jar类库(使用的版本为2.6.9),并将其添加到classpath中。附jxl.jar下载地址:http://sourceforge.net/projects/jexcelapi/files/jexcelapi/
2、名词解释
工作簿(workbook):在excel中对应于一个excel文件工作表(sheet):在excel中对应于如下截图中的红色圈中部分
单元格对象:在excel中对应于如下截图中的红色圈中部分
3、使用jxl读取excel文件
[java] viewplain copy
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.read.biff.BiffException;
public class ReadExcel {
public static void main(String[] args) throws BiffException, IOException {
// 1、构造excel文件输入流对象
String sFilePath = "D:/1.xls";
InputStream is = new FileInputStream(sFilePath);
// 2、声明工作簿对象
Workbook rwb = Workbook.getWorkbook(is);
// 3、获得工作簿的个数,对应于一个excel中的工作表个数
rwb.getNumberOfSheets();
Sheet oFirstSheet = rwb.getSheet(0);// 使用索引形式获取第一个工作表,也可以使用rwb.getSheet(sheetName);其中sheetName表示的是工作表的名称
// System.out.println("工作表名称:" + oFirstSheet.getName());
int rows = oFirstSheet.getRows();//获取工作表中的总行数
int columns = oFirstSheet.getColumns();//获取工作表中的总列数
for (int i = 0; i < rows; i++) {
for (int j = 0; j < columns; j++) {
Cell oCell= oFirstSheet.getCell(j,i);//需要注意的是这里的getCell方法的参数,第一个是指定第几列,第二个参数才是指定第几行
System.out.println(oCell.getContents()+"\r\n");
}
}
}
}
4、向excel文件中写内容
[java] viewplain copy
import java.io.File;
import java.io.IOException;
import jxl.Workbook;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;
public class WriteExcel {
public static void main(String[] args) throws IOException,
RowsExceededException, WriteException {
// 1、创建工作簿(WritableWorkbook)对象,打开excel文件,若文件不存在,则创建文件
WritableWorkbook writeBook = Workbook.createWorkbook(new File(
"D://write.xls"));
// 2、新建工作表(sheet)对象,并声明其属于第几页
WritableSheet firstSheet = writeBook.createSheet("第一个工作簿", 1);// 第一个参数为工作簿的名称,第二个参数为页数
WritableSheet secondSheet = writeBook.createSheet("第二个工作簿", 0);
// 3、创建单元格(Label)对象,
Label label1 = new Label(1, 2, "test1");// 第一个参数指定单元格的列数、第二个参数指定单元格的行数,第三个指定写的字符串内容
firstSheet.addCell(label1);
Label label2 = new Label(1, 2, "test2");
secondSheet.addCell(label2);
// 4、打开流,开始写文件
writeBook.write();
// 5、关闭流
writeBook.close();
}
}
5、合并单元格
[java] viewplain copy
import java.io.File;
import java.io.IOException;
import jxl.Workbook;
import jxl.read.biff.BiffException;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;
public class MergeCell {
public static void main(String[] args) throws IOException,
RowsExceededException, WriteException, BiffException {
// 1、创建WritableWorkbook对象
File file = new File("D:/write.xls");
WritableWorkbook oWritableBK = Workbook.createWorkbook(file);
// 2、创建WritableSheet对象
WritableSheet oWritableSheet = oWritableBK.createSheet("testsheet1", 0);
// 3、添加单元格
Label label1 = new Label(0, 0, "test1");
oWritableSheet.addCell(label1);
Label label30 = new Label(3, 1, "我是合并后的单元格!");
oWritableSheet.addCell(label30);
//4、 合并单元格
oWritableSheet.mergeCells(3,1, 9, 1);// 参数说明,前两个参数为待合并的起始单元格位置,后两个参数用来指定结束单元格位置(列和行)
oWritableBK.write();
oWritableBK.close();
}
}
POI和jxl的比较
POI不支持写入图片(jxl支持,但是只支持png格式的图片)POI对公式的支持比较好,jxl对公式的支持不如POI。所以财务软件用POI较好
多少数据量时出现内存溢出:
使用POI:运行到2800条左右就报内存溢出,使用jxl到3000条左右报内存溢出
读取excel速率:POI优于jxl
插入数据速率:jxl优于POI
JSP使用commons-fileupload实现文件上传
1、准备:将commons-fileupload-1.1.zip和commons-io-1.1.zip复制到"\WEB-INF\lib"目录下
2、首先是Servlet:FileUpload.java
package servlet; import java.io.File; import java.io.IOException; import java.io.PrintWriter; import java.util.*; import java.util.regex.Pattern; import java.util.regex.Matcher; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.commons.fileupload.FileItem; import org.apache.commons.fileupload.FileUploadException; import org.apache.commons.fileupload.disk.DiskFileItemFactory; import org.apache.commons.fileupload.servlet.ServletFileUpload; public class FileUpload extends HttpServlet { private String uploadPath="E:\\addnetFile\\";//要上传文件的目录 private File tempPath=new File("E:\\tempFile\\");//存放上传的文件的目录 public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { } public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html;charset=GB2312"); response.setCharacterEncoding("gb2312"); PrintWriter out=response.getWriter(); out.println("请求内容的长度为:"+request.getContentLength()); out.println("请求内容的类型为:"+request.getContentType()); DiskFileItemFactory factory=new DiskFileItemFactory(); factory.setRepository(tempPath); factory.setSizeThreshold(4096); ServletFileUpload upload=new ServletFileUpload(factory); upload.setSizeMax(1000000); List<?> fileitems=null; try{ fileitems=upload.parseRequest(request); Iterator<?> iterator=fileitems.iterator(); String regex=".+\\\\(.+)$"; String[] errortype={".exe",".com",".cgi",".asp"}; Pattern p=Pattern.compile(regex); while(iterator.hasNext()){ FileItem item=(FileItem) iterator.next(); if(!item.isFormField()){ String name=item.getName(); long size=item.getSize(); if(name==null||name.equals("")&&size==0) continue; Matcher m=p.matcher(name); if(m.find()){ for(int temp=0;temp<errortype.length;temp++){ if(m.group(1).endsWith(errortype[temp])) throw new IOException(name+":wrong type"); } try{ item.write(new File(tempPath,m.group(1))); out.println(name+" "+size+"<br/>"); out.println("上传成功"); }catch(Exception e){ out.println("333"+e); } } else{ throw new IOException("fail to upload"); } } } }catch(IOException e){ out.println("222"+e); } catch(FileUploadException e1){ e1.printStackTrace(); out.println("111"+e1); } } public void init() throws ServletException { if(!new File(uploadPath).isDirectory()) new File(uploadPath).mkdir(); if(!tempPath.isDirectory()) tempPath.mkdir(); } public void destroy(){ super.destroy(); } }
3、其次是html:Uploadfile.html
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>Uploadfilel.html</title> <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"> <meta http-equiv="description" content="this is my page"> <meta http-equiv="content-type" content="text/html; charset=UTF-8"> <!--<link rel="stylesheet" type="text/css" href="./styles.css">--> </head> <body> <form action="/Firstjsp/servlet/FileUpload" method="post" enctype="multipart/form-data" name="form1"> <input type="file" name="file"/> <input type="submit" name="submit" value="upload"/> </form> <form action="/Firstjsp/servlet/FileUpload" method="post" enctype="multipart/form-data" name="uploadform"> <table> <tr> <td> 文件1:<input type="file" name="X" size="40"/> </td> </tr> <tr> <td> 文件2:<input type="file" name="Y" size="40"/> </td> </tr> <tr> <td> 文件3:<input type="file" name="Z" size="40"/> </td> </tr> </table> <input type="submit" name="upload" value="开始上传"/> </form> </body> </html>
4、最后是配置web.xml
<servlet> <description>This is the description of my J2EE component</description> <display-name>This is the display name of my J2EE component</display-name> <servlet-name>FileUpload</servlet-name> <servlet-class>servlet.FileUpload</servlet-class> </servlet> <servlet-mapping> <servlet-name>FileUpload</servlet-name> <url-pattern>/servlet/FileUpload</url-pattern>
首先运行html,servlet处理上传请求
网上相关的例子比较多,这里只给出最简单的一个,使用commons-fileupload组件完成上传。首先你需要下载组件,按说从官网上下载文件应该就可以了,不过貌似最新的这个少了一个jar包,所以我往网盘里传了一份,大家自行下载:http://u.115.com/file/f4694e2ffc http://u.115.com/file/f4e87888d0 ,把这俩文件放到工程WEN-INF的lib目录下。
首先建立一个Servlet:UploadServlet.java:
package com.web; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.commons.fileupload.*; import java.util.*; import java.io.*; import org.apache.commons.fileupload.servlet.*; import org.apache.commons.fileupload.disk.DiskFileItemFactory; /** * 上传文件的Servlet * @author 胡阳 * */ public class UploadServlet extends HttpServlet { public void doPost(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException { System.out.println("dddd"); res.setContentType("text/html; charset=GB18030"); PrintWriter out = res.getWriter(); System.out.println(req.getContentLength()); System.out.println(req.getContentType()); DiskFileItemFactory factory = new DiskFileItemFactory(); // 允许设置内存中存储数据的门限,单位:字节 factory.setSizeThreshold(4096); // 如果文件大小大于SizeThreshold,则保存到临时目录 factory.setRepository(new File("D:\\")); ServletFileUpload upload = new ServletFileUpload(factory); // 最大上传文件,单位:字节 upload.setSizeMax(1000000); try { List fileItems = upload.parseRequest(req); Iterator iter = fileItems.iterator(); if (iter.hasNext()) { FileItem item = (FileItem) iter.next(); String fileName = item.getName(); // 忽略其他不是文件域的所有表单信息 if (!item.isFormField()) { try { //取得文件名 fileName = fileName.substring(fileName.lastIndexOf("\\") + 1, fileName.length()); // 保存上传的文件到指定的目录指定文件名中 item.write(new File("D:\\",fileName)); } catch (Exception e) { out.println(e); } } else { throw new IOException("fail to upload"); } } } catch (FileUploadException e) { out.println(e); } } }
然后是web.xml文件:
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:javaee="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"> <servlet> <servlet-name>UploadServlet</servlet-name> <servlet-class>com.web.UploadServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>UploadServlet</servlet-name> <url-pattern>/servlet/UploadServlet</url-pattern> </servlet-mapping> </web-app>
上传文件的页面:upload.jsp
<%@ page language="java" contentType="text/html; charset=GB18030" pageEncoding="GB18030"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=GB18030"> <title>Insert title here</title> </head> <body> //注意action地址,还有enctype要写成multipart/form-data,和method="POST" <form name="uploadform" method="POST" action="./servlet/UploadServlet" ENCTYPE="multipart/form-data"> <table border="1" width="450" cellpadding="4" cellspacing="2" bordercolor="#9BD7FF"> <tr> <td width="100%" colspan="2"> 文件:<input name="x" size="40" type="file"> </td> </tr> </table> <br/><br/> <table> <tr><td align="center"><input name="upload" type="submit" value="开始上传"/></td></tr> </table> </form> </body> </html>
更多内容可以参考这里:http://www.blogjava.net/freeman1984/archive/2007/09/28/149358.html
相关文章推荐
- Java使用jxl操作Excel
- java中使用JXL对Excel文件进行数据的写入、导出操作
- jxl的使用总结(java操作excel)
- jxl的使用总结(java操作excel)
- 使用java操作Excel入门 ---- jxl介绍
- jxl的使用总结(java操作excel)
- 在java中使用jxl操作excel
- 在java中使用jxl操作excel
- java中使用JXL对Excel文件进行数据的写入、导出操作
- JAVA中使用JXL操作EXCEL
- java使用jxl,jExcelAPI操作excel代码总结
- 在java中使用jxl操作excel
- Java操作Excel使用jxl.jar--读取Excel
- Java环境下使用JXL操作Excel使用笔记
- jxl的使用总结(java操作excel)
- java使用jxl简单操作Excel
- Java环境下使用JXL操作Excel使用笔记
- Java使用jxl.jar操作Excel
- Java操作Excel(使用JXL)
- 使用Java Excel API (JXL)在Java环境下操作Excel