【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教程(易百教 ...
随机推荐
- 黄聪:.NET中zip的压缩和解压——SharpCompress
使用Packaging无法实现通用的zip(使用其他工具压缩)的解压,只支持通过Packaging压缩包zip的解压,而SharpZipLib是基于“GPL”开源方式,风险比较大.在codeplex找 ...
- 【IIS错误 - HTTP 错误 500.19】HTTP 错误 500.19- Internal Server Error 错误解决方法(一)
刚在本机部署了一个WebService测试,浏览的时候出现了“HTTP 错误 500.19 - Internal Server Error ”错误,如下图: 经过检查发现是由于先安装vs2008后安装 ...
- 廖雪峰Java2面向对象编程-4抽象类和接口-2接口
1.接口的定义 抽象方法本质上是定义接口规范. 在抽象类中定义了一个抽象方法,子类中必须实现这个抽象方法. public abstract class Person{ public abstract ...
- etcd集群部署与遇到的坑(转)
原文 https://www.cnblogs.com/breg/p/5728237.html etcd集群部署与遇到的坑 在k8s集群中使用了etcd作为数据中心,在实际操作中遇到了一些坑.今天记录一 ...
- ntp服务问题
原本国内的主机直接指向阿里云就可以时间同步了 但是国外的主机 却有报错 这个报错还没有解决 1 Oct 03:47:30 ntpdate[20969]: no server suitable fo ...
- 第一天课程:第一个python程序print say hello
print("Hello World") linux下要加可执行权限 chmod 755 hello.py 权限755,7=4+2+1,4是读,2是写,1是执行,第一个7代表用户, ...
- [UE4]GameMode、GameInstance、GameState、PlayerState、PlayerController
一.只有PlayerController和Pawn/Character才有输入事件(键盘.鼠标等等),PlayerState没有输入事件. 二.对于需要跨域关卡的数据信息,根据上图所知需要放到Game ...
- [UE4]射击产生弹孔:Spawn Decal At Location、Spawn Decal Attached
Spawn Decal At Location.Spawn Decal Attached 在指定的位置生成一个材质贴上去 产生随意旋转角度
- Android毛玻璃模糊化效果处理
三种方法 第一种:比较简单,性能比较低 /** * 通过调用系统高斯模糊api的方法模糊 * * @param bitmap source bitmap * @par ...
- switch case 变量初始化问题
今天再写alsa的时候遇到一个稀奇古怪的问题,网上看了下资料,摘出来入下 代码: int main() { ; switch(a) { : ; break; : break; default: bre ...