【JAVA】使用Aphache poi操作EXCEL 笔记
1 下载poi,地址
http://poi.apache.org/
选择3.9版本。
2
刚开始尝试 把poi.jar放在D:\Program Files\java\jdk1.6.0_20\lib(不管用。删除)
若你的是web Project工程,就直接把poi.jar包复制粘贴到webroot的web-inf下面的lib文件夹里面;
若你的是java Project工程,就打开盖工程的属性(Properties)找到他的java build path然后有个Libraries选项卡在右侧可通过Add jars来添加放置在工程里面的poi.jar包,如果你的这个poi.jar包不是放在工程中的,可以通过add external jars来添加外部jar包
3 创建1个EXCEL文件。
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List; import org.apache.poi.hssf.usermodel.HSSFWorkbook; public class PoiMain { /**
* @param args
*/
public static void main(String[] args) {
try {
// 创建一个Excel文件
HSSFWorkbook wb = new HSSFWorkbook();
String path = "D:\\Workspace\\TestPOI\\a.xls";
FileOutputStream fileOut = new FileOutputStream(new File(path));
wb.write(fileOut);
fileOut.close();
} catch (Exception e) {
// TODO: handle exception
} } }
包结构
4 创建一个Excle,并写入各种格式的内容
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List; import org.apache.poi.hssf.usermodel.*;//Excel所有 public class PoiMain { /**
* @param args
* 创建一个xls文件
* 用到org.apache.poi.hssf.usermodel.HSSFWorkbook;//Excel的文档对象
* 主程序,唯一程序,排他
* @作者 小白
*/
// public static void main(String[] args) {
// try {
// // 创建一个Excel文件
// HSSFWorkbook wb = new HSSFWorkbook();
// String path = "D:\\Workspace\\TestPOI\\a.xls";
// FileOutputStream fileOut = new FileOutputStream(new File(path));
// wb.write(fileOut);
// fileOut.close();
// } catch (Exception e) {
// // TODO: handle exception
// }
//
// } /**
* @param args
* 创建一个xls文件
* 用到org.apache.poi.hssf.usermodel.*;//Excel所有
* 主程序,唯一程序,排他
*/
public static void main(String[] args) throws IOException{
try {
HSSFWorkbook wb = new HSSFWorkbook(); //建立新HSSFWorkbook对象
HSSFSheet sheet = wb.createSheet("new sheet"); //建立新的sheet对象 //第0行
HSSFRow row = sheet.createRow((short)0);
//在sheet里创建一行,参数为行号(第一行,此处可想象成数组)
HSSFCell cell = row.createCell(0);
//在row里建立新cell(单元格),参数为列号(第一列)
cell.setCellValue(1) ;//设置cell的整数类型的值
row.createCell(1).setCellValue(1.2); //设置cell浮点类型的值
row.createCell(2).setCellValue("haha"); //设置cell字符类型的值
row.createCell(3).setCellValue(true); //设置cell布尔类型的值 HSSFCellStyle cellStyle = wb.createCellStyle(); //建立新的cell样式
HSSFDataFormat format= wb.createDataFormat();
cellStyle.setDataFormat(format.getFormat("yyyy年mm月d日 hh:mm:ss"));//这两行是日期格式的重点
//设置cell样式为定制的日期格式
HSSFCell dCell =row.createCell(4);
dCell.setCellValue(new Date()); //设置cell为日期类型的值
dCell.setCellStyle(cellStyle); //设置该cell日期的显示格式 HSSFCell csCell =row.createCell(5);
// csCell.setEncoding(HSSFCell.ENCODING_UTF_16); //设置cell编码解决中文高位字节截断
csCell.setCellValue("这是中文的测试"); //设置中西文结合字符串 row.createCell(6).setCellType(HSSFCell.CELL_TYPE_ERROR);
//建立错误cell //第1行
HSSFRow row1 = sheet.createRow(1);
row1.createCell(0).setCellValue(false);
row1.createCell(1).setCellValue(19907);
row1.createCell(2).setCellValue("中华民国"); //创建生成文件
String path = "D:\\Workspace\\TestPOI\\ab.xls";
FileOutputStream fileOut = new FileOutputStream(new File(path));
wb.write(fileOut);
fileOut.close(); } catch (Exception e) {
// TODO: handle exception } } }
包结构
表内容
5 把刚才创建的东东读出来
为了方便主函数操作,把读写类和测试类分开了
包结构:
主类 PoiMain.java
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List; import org.apache.poi.hssf.usermodel.*;//Excel所有 public class PoiMain { /**
* @param args
* 创建一个xls文件
* 用到org.apache.poi.hssf.usermodel.HSSFWorkbook;//Excel的文档对象
* 主程序,唯一程序,排他
* @作者 小白
*/
// public static void main(String[] args) {
// try {
// // 创建一个Excel文件
// HSSFWorkbook wb = new HSSFWorkbook();
// String path = "D:\\Workspace\\TestPOI\\a.xls";
// FileOutputStream fileOut = new FileOutputStream(new File(path));
// wb.write(fileOut);
// fileOut.close();
// } catch (Exception e) {
// // TODO: handle exception
// }
//
// } /**
* @param args
* 创建一个xls文件
* 用到org.apache.poi.hssf.usermodel.*;//Excel所有
* 主程序,唯一程序,排他
*/
public static void main(String[] args) throws IOException{ //创建Excel
// CreatExcelTest cTest = new CreatExcelTest();
// cTest.creatExcel(); //读取Excel
GetVlueTest gTest = new GetVlueTest();
gTest.getvalue(); // TestPrint testPrint = new TestPrint();
// testPrint.TestPrint(); } }
创建Excel的类 CreatExcelTest.java
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List; import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFDataFormat;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
public class CreatExcelTest { public static void creatExcel(){
try {
HSSFWorkbook wb = new HSSFWorkbook(); //建立新HSSFWorkbook对象
HSSFSheet sheet = wb.createSheet("new sheet"); //建立新的sheet对象 //第0行
HSSFRow row = sheet.createRow((short)0);
//在sheet里创建一行,参数为行号(第一行,此处可想象成数组)
HSSFCell cell = row.createCell(0);
//在row里建立新cell(单元格),参数为列号(第一列)
cell.setCellValue(1) ;//设置cell的整数类型的值
row.createCell(1).setCellValue(1.2); //设置cell浮点类型的值
row.createCell(2).setCellValue("haha"); //设置cell字符类型的值
row.createCell(3).setCellValue(true); //设置cell布尔类型的值 HSSFCellStyle cellStyle = wb.createCellStyle(); //建立新的cell样式
HSSFDataFormat format= wb.createDataFormat();
cellStyle.setDataFormat(format.getFormat("yyyy年mm月d日 hh:mm:ss"));//这两行是日期格式的重点
//设置cell样式为定制的日期格式
HSSFCell dCell =row.createCell(4);
dCell.setCellValue(new Date()); //设置cell为日期类型的值
dCell.setCellStyle(cellStyle); //设置该cell日期的显示格式 HSSFCell csCell =row.createCell(5);
// csCell.setEncoding(HSSFCell.ENCODING_UTF_16); //设置cell编码解决中文高位字节截断
csCell.setCellValue("这是中文的测试"); //设置中西文结合字符串 row.createCell(6).setCellType(HSSFCell.CELL_TYPE_ERROR);
//建立错误cell //第1行
HSSFRow row1 = sheet.createRow(1);
row1.createCell(0).setCellValue(false);
row1.createCell(1).setCellValue(19907);
row1.createCell(2).setCellValue("中华民国a "); //创建生成文件
String path = "D:\\Workspace\\TestPOI\\abcd.xls";
FileOutputStream fileOut = new FileOutputStream(new File(path));
wb.write(fileOut);
fileOut.close(); } catch (Exception e) {
// TODO: handle exception }
} }
读取Excel的类,读取出来的内容打印在控制台了。
import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List; import javax.tools.JavaFileObject.Kind; import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFDataFormat;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook; public class GetVlueTest { public static void getvalue(){ try { String filePath = "D:\\Workspace\\TestPOI\\b.xls";
HSSFWorkbook hssfWorkbook = new HSSFWorkbook(new FileInputStream(filePath));
HSSFSheet hssfSheet = hssfWorkbook.getSheetAt(0);
int i = hssfSheet.getLastRowNum();//最后一行行标,比行数小1 for(int k=0; k<=i;k++){ int m = hssfSheet.getRow(k).getLastCellNum();//获取列数,比最后一列列标大1 for(int j=0; j<m;j++)
{
hssfSheet.getRow(k).getCell(j).setCellType(HSSFCell.CELL_TYPE_STRING);//为了打印输出,强制把不是字符串的东东转换成字符串
System.out.println(hssfSheet.getRow(k).getCell(j).getStringCellValue());
} } } catch (Exception e) {
// TODO: handle exception } } }
【JAVA】使用Aphache poi操作EXCEL 笔记的更多相关文章
- java使用Apache POI操作excel文件
官方介绍 HSSF is the POI Project's pure Java implementation of the Excel '97(-2007) file format. XSSF is ...
- java 使用jxl poi 操作excel
java操作excel 创建.修改 xls 文件 JAVA操作Excel文件 Java生成和操作Excel文件 java导出Excel通用方法 Java 实现导出excel表 POI Java PO ...
- java使用POI操作excel文件,实现批量导出,和导入
一.POI的定义 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作Exc ...
- java里poi操作excel的工具类(兼容各版本)
转: java里poi操作excel的工具类(兼容各版本) 下面是文件内具体内容,文件下载: import java.io.FileNotFoundException; import java.io. ...
- Java POI操作Excel注意点
excel的行索引和列索引都是从0开始,而行号和列号都是从1开始 POI·操作excel基本上都是使用索引 XSSFRow对象的 row.getLastCellNum() 方法返回的是当前行最后有效列 ...
- POI操作Excel
POI和Excel简介 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作 ...
- 自己封装的poi操作Excel工具类
自己封装的poi操作Excel工具类 在上一篇文章<使用poi读写Excel>中分享了一下poi操作Excel的简单示例,这次要分享一下我封装的一个Excel操作的工具类. 该工具类主要完 ...
- 自己的包poi操作Excel工具
在前面的文章<使用poi读写Excel>中分享了一下poi操作Excel的简单演示样例.这次要分享一下我封装的一个Excel操作的工具类. 该工具类主要完毕的功能是:读取Excel.汇总E ...
- POI操作Excel(xls、xlsx)
阿帕奇官网:http://poi.apache.org/ POI3.17下载:http://poi.apache.org/download.html#POI-3.17 POI操作Excel教程(易百教 ...
随机推荐
- phoenix psqlline输入命令无法删除问题解决技巧
一.引言: phoenix psqlline使用过程中,使用CRT客户端,命令输入后无法删除,想起曾经处理HBaseShell输入后无法删除的解决办法,尝试了一下,居然有效,还是分享给大家把. 二.操 ...
- C#对Mongodb数组对象操作
Mongo对数据的存储非常随意,需要修改对象中的数组对象时,就会变得比较复杂. 类中的类对象可以直接通过“.”例如:Department.User.name 类中的对象User是数组时可以用Depar ...
- CentOS7安装配置PostgreSQL9.6
本文涉及CentOS7下PostgreSQL9.6的yum安装,访问配置及简单使用. 一.验证环境 1. 操作系统 CentOS-7-x86_64-Everything-1511 2. Postgre ...
- 廖雪峰Java5集合-3Map-Properties的使用
Properties用于读取配置 properties文件只能使用ASCII码 #表示注释 可以从文件系统读取.properties文件 Properties props = new Properti ...
- Zabbix agentd 命令
#zabbix_agentd -p 查看zabbix所有的内置监控项 [root@nod01 zabbix_agentd.d]# zabbix_agentd -pagent.hostname [s|Z ...
- VMware虚拟机上配置nginx后,本机无法访问问题(转载)
转自:http://www.server110.com/nginx/201407/10794.html 把nginx装在CentOS上,用本机访问虚拟机的时候却出现了不能访问的问题,查了资料以后,原来 ...
- SpringMVC 源码分析
一个东西用久了,自然就会从仅使用的层面上升到探究其原理的层面,在javaweb中springmvc更是如此,越是优秀的框架,其底层实现代码更是复杂,而在我看来,一个优秀程序猿就相当于一名武林高手,不断 ...
- [SQL]用SQL语句断开某个数据库的所有活动连接
USE master go IF EXISTS ( SELECT * FROM dbo.sysobjects WHERE id = OBJECT_ID(N'[dbo].[P_KillConnectio ...
- java类加载器 Bootstrap、ExtClassLoader、AppClassLoader的关系
1.Bootstrap. ExtClassLoader. AppClassLoader是java最根正苗红的类加载器.2.Bootstrap是本地代码编写的(例如C), ExtClassLoader. ...
- Flume数据采集准备
, flume的官网:http://flume.apache.org/ flume的下载地址:http://flume.apache.org/download.html 这里我们用的是apache版本 ...