1. package com.tools.poi.lesson1;
  2. import java.io.FileInputStream;
  3. import java.io.FileNotFoundException;
  4. import java.io.FileOutputStream;
  5. import java.io.IOException;
  6. import java.text.ParseException;
  7. import java.text.SimpleDateFormat;
  8. import java.util.ArrayList;
  9. import java.util.List;
  10. import org.apache.poi.hssf.usermodel.HSSFCell;
  11. import org.apache.poi.hssf.usermodel.HSSFCellStyle;
  12. import org.apache.poi.hssf.usermodel.HSSFRow;
  13. import org.apache.poi.hssf.usermodel.HSSFSheet;
  14. import org.apache.poi.hssf.usermodel.HSSFWorkbook;
  15. import org.apache.poi.hssf.util.HSSFColor;
  16. import org.apache.poi.poifs.filesystem.POIFSFileSystem;
  17. import org.apache.poi.ss.usermodel.Cell;
  18. import org.apache.poi.ss.usermodel.CellStyle;
  19. import com.tools.poi.bean.Student;
  20. public class ExcelUtilWithHSSF {
  21. public static void main(String[] args) {
  22. try {
  23. getExcelAsFile("aaa");
  24. } catch (FileNotFoundException e) {
  25. e.printStackTrace();
  26. } catch (IOException e) {
  27. e.printStackTrace();
  28. }
  29. //      try {
  30. //          CreateExcelDemo1();
  31. //      } catch (ParseException e) {
  32. //          e.printStackTrace();
  33. //      }
  34. }
  35. /**
  36. * 得到Excel,并解析内容
  37. * @param file
  38. * @throws FileNotFoundException
  39. * @throws IOException
  40. */
  41. public static void getExcelAsFile(String file) throws FileNotFoundException, IOException{
  42. //1.得到Excel常用对象
  43. //      POIFSFileSystem fs = new POIFSFileSystem(new FileInputStream("d:/FTP/test.xls"));
  44. POIFSFileSystem fs = new POIFSFileSystem(new FileInputStream("d:/FTP/new1.xls"));
  45. //2.得到Excel工作簿对象
  46. HSSFWorkbook wb = new HSSFWorkbook(fs);
  47. //3.得到Excel工作表对象
  48. HSSFSheet sheet = wb.getSheetAt(0);
  49. //总行数
  50. int trLength = sheet.getLastRowNum();
  51. //4.得到Excel工作表的行
  52. HSSFRow row = sheet.getRow(0);
  53. //总列数
  54. int tdLength = row.getLastCellNum();
  55. //5.得到Excel工作表指定行的单元格
  56. HSSFCell cell = row.getCell((short)1);
  57. //6.得到单元格样式
  58. CellStyle cellStyle = cell.getCellStyle();
  59. for(int i=0;i<trLength;i++){
  60. //得到Excel工作表的行
  61. HSSFRow row1 = sheet.getRow(i);
  62. for(int j=0;j<tdLength;j++){
  63. //得到Excel工作表指定行的单元格
  64. HSSFCell cell1 = row1.getCell(j);
  65. /**
  66. * 为了处理:Excel异常Cannot get a text value from a numeric cell
  67. * 将所有列中的内容都设置成String类型格式
  68. */
  69. if(cell1!=null){
  70. cell1.setCellType(Cell.CELL_TYPE_STRING);
  71. }
  72. //获得每一列中的值
  73. System.out.print(cell1.getStringCellValue()+"\t\t\t");
  74. }
  75. System.out.println();
  76. }
  77. }
  78. /**
  79. * 创建Excel,并写入内容
  80. */
  81. public static void CreateExcel(){
  82. //1.创建Excel工作薄对象
  83. HSSFWorkbook wb = new HSSFWorkbook();
  84. //2.创建Excel工作表对象
  85. HSSFSheet sheet = wb.createSheet("new Sheet");
  86. //3.创建Excel工作表的行
  87. HSSFRow row = sheet.createRow(6);
  88. //4.创建单元格样式
  89. CellStyle cellStyle =wb.createCellStyle();
  90. // 设置这些样式
  91. cellStyle.setFillForegroundColor(HSSFColor.SKY_BLUE.index);
  92. cellStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
  93. cellStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN);
  94. cellStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);
  95. cellStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);
  96. cellStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);
  97. cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
  98. //5.创建Excel工作表指定行的单元格
  99. row.createCell(0).setCellStyle(cellStyle);
  100. //6.设置Excel工作表的值
  101. row.createCell(0).setCellValue("aaaa");
  102. row.createCell(1).setCellStyle(cellStyle);
  103. row.createCell(1).setCellValue("bbbb");
  104. //设置sheet名称和单元格内容
  105. wb.setSheetName(0,"第一张工作表");
  106. //设置单元格内容   cell.setCellValue("单元格内容");
  107. // 最后一步,将文件存到指定位置
  108. try
  109. {
  110. FileOutputStream fout = new FileOutputStream("E:/students.xls");
  111. wb.write(fout);
  112. fout.close();
  113. }
  114. catch (Exception e)
  115. {
  116. e.printStackTrace();
  117. }
  118. }
  119. /**
  120. * 创建Excel的实例
  121. * @throws ParseException
  122. */
  123. public static void CreateExcelDemo1() throws ParseException{
  124. List list = new ArrayList();
  125. SimpleDateFormat df = new SimpleDateFormat("yyyy-mm-dd");
  126. Student user1 = new Student(1, "张三", 16,true, df.parse("1997-03-12"));
  127. Student user2 = new Student(2, "李四", 17,true, df.parse("1996-08-12"));
  128. Student user3 = new Student(3, "王五", 26,false, df.parse("1985-11-12"));
  129. list.add(user1);
  130. list.add(user2);
  131. list.add(user3);
  132. // 第一步,创建一个webbook,对应一个Excel文件
  133. HSSFWorkbook wb = new HSSFWorkbook();
  134. // 第二步,在webbook中添加一个sheet,对应Excel文件中的sheet
  135. HSSFSheet sheet = wb.createSheet("学生表一");
  136. // 第三步,在sheet中添加表头第0行,注意老版本poi对Excel的行数列数有限制short
  137. HSSFRow row = sheet.createRow((int) 0);
  138. // 第四步,创建单元格,并设置值表头 设置表头居中
  139. HSSFCellStyle style = wb.createCellStyle();
  140. style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 创建一个居中格式
  141. HSSFCell cell = row.createCell((short) 0);
  142. cell.setCellValue("学号");
  143. cell.setCellStyle(style);
  144. cell = row.createCell((short) 1);
  145. cell.setCellValue("姓名");
  146. cell.setCellStyle(style);
  147. cell = row.createCell((short) 2);
  148. cell.setCellValue("年龄");
  149. cell.setCellStyle(style);
  150. cell = row.createCell((short) 3);
  151. cell.setCellValue("性别");
  152. cell.setCellStyle(style);
  153. cell = row.createCell((short) 4);
  154. cell.setCellValue("生日");
  155. cell.setCellStyle(style);
  156. // 第五步,写入实体数据 实际应用中这些数据从数据库得到,
  157. for (int i = 0; i < list.size(); i++)
  158. {
  159. row = sheet.createRow((int) i + 1);
  160. Student stu = (Student) list.get(i);
  161. // 第四步,创建单元格,并设置值
  162. row.createCell((short) 0).setCellValue((double) stu.getId());
  163. row.createCell((short) 1).setCellValue(stu.getName());
  164. row.createCell((short) 2).setCellValue((double) stu.getAge());
  165. row.createCell((short)3).setCellValue(stu.getSex()==true?"男":"女");
  166. cell = row.createCell((short) 4);
  167. cell.setCellValue(new SimpleDateFormat("yyyy-mm-dd").format(stu
  168. .getBirthday()));
  169. }
  170. // 第六步,将文件存到指定位置
  171. try
  172. {
  173. FileOutputStream fout = new FileOutputStream("E:/students.xls");
  174. wb.write(fout);
  175. fout.close();
  176. }
  177. catch (Exception e)
  178. {
  179. e.printStackTrace();
  180. }
  181. }
  182. }
 

XSSF方式:

[java] view plain copy

 
  1. package com.tools.poi.lesson1;
  2. import java.io.File;
  3. import java.io.FileInputStream;
  4. import java.io.FileNotFoundException;
  5. import java.io.FileOutputStream;
  6. import java.io.IOException;
  7. import java.io.InputStream;
  8. import java.io.OutputStream;
  9. import java.text.ParseException;
  10. import java.text.SimpleDateFormat;
  11. import java.util.ArrayList;
  12. import java.util.List;
  13. import org.apache.poi.hssf.usermodel.HSSFCell;
  14. import org.apache.poi.hssf.usermodel.HSSFCellStyle;
  15. import org.apache.poi.hssf.usermodel.HSSFRow;
  16. import org.apache.poi.hssf.usermodel.HSSFSheet;
  17. import org.apache.poi.hssf.usermodel.HSSFWorkbook;
  18. import org.apache.poi.hssf.util.HSSFColor;
  19. import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
  20. import org.apache.poi.poifs.filesystem.POIFSFileSystem;
  21. import org.apache.poi.ss.usermodel.Cell;
  22. import org.apache.poi.ss.usermodel.CellStyle;
  23. import org.apache.poi.ss.usermodel.Row;
  24. import org.apache.poi.ss.usermodel.Sheet;
  25. import org.apache.poi.ss.usermodel.Workbook;
  26. import org.apache.poi.ss.usermodel.WorkbookFactory;
  27. import org.apache.poi.ss.util.WorkbookUtil;
  28. import com.tools.poi.bean.Student;
  29. public class ExcelUtilWithXSSF {
  30. public static void main(String[] args) {
  31. try {
  32. getExcelAsFile("d:/FTP/系统报表.xls");
  33. } catch (FileNotFoundException e) {
  34. e.printStackTrace();
  35. } catch (IOException e) {
  36. e.printStackTrace();
  37. } catch (InvalidFormatException e) {
  38. e.printStackTrace();
  39. }
  40. //      try {
  41. //          CreateExcelDemo1();
  42. //      } catch (ParseException e) {
  43. //          e.printStackTrace();
  44. //      }
  45. }
  46. /**
  47. * 得到Excel,并解析内容  对2007及以上版本 使用XSSF解析
  48. * @param file
  49. * @throws FileNotFoundException
  50. * @throws IOException
  51. * @throws InvalidFormatException
  52. */
  53. public static void getExcelAsFile(String file) throws FileNotFoundException, IOException, InvalidFormatException{
  54. //      //1.得到Excel常用对象
  55. //      POIFSFileSystem fs = new POIFSFileSystem(new FileInputStream("d:/FTP/new1.xls"));
  56. //      //2.得到Excel工作簿对象
  57. //      HSSFWorkbook wb = new HSSFWorkbook(fs);
  58. InputStream ins = null;
  59. Workbook wb = null;
  60. ins=new FileInputStream(new File(file));
  61. //ins= ExcelService.class.getClassLoader().getResourceAsStream(filePath);
  62. wb = WorkbookFactory.create(ins);
  63. ins.close();
  64. //3.得到Excel工作表对象
  65. Sheet sheet = wb.getSheetAt(0);
  66. //总行数
  67. int trLength = sheet.getLastRowNum();
  68. //4.得到Excel工作表的行
  69. Row row = sheet.getRow(0);
  70. //总列数
  71. int tdLength = row.getLastCellNum();
  72. //5.得到Excel工作表指定行的单元格
  73. Cell cell = row.getCell((short)1);
  74. //6.得到单元格样式
  75. CellStyle cellStyle = cell.getCellStyle();
  76. for(int i=5;i<trLength;i++){
  77. //得到Excel工作表的行
  78. Row row1 = sheet.getRow(i);
  79. for(int j=0;j<tdLength;j++){
  80. //得到Excel工作表指定行的单元格
  81. Cell cell1 = row1.getCell(j);
  82. /**
  83. * 为了处理:Excel异常Cannot get a text value from a numeric cell
  84. * 将所有列中的内容都设置成String类型格式
  85. */
  86. if(cell1!=null){
  87. cell1.setCellType(Cell.CELL_TYPE_STRING);
  88. }
  89. if(j==5&&i<=10){
  90. cell1.setCellValue("1000");
  91. }
  92. //获得每一列中的值
  93. System.out.print(cell1+"                   ");
  94. }
  95. System.out.println();
  96. }
  97. //将修改后的数据保存
  98. OutputStream out = new FileOutputStream(file);
  99. wb.write(out);
  100. }
  101. /**
  102. * 创建Excel,并写入内容
  103. */
  104. public static void CreateExcel(){
  105. //1.创建Excel工作薄对象
  106. HSSFWorkbook wb = new HSSFWorkbook();
  107. //2.创建Excel工作表对象
  108. HSSFSheet sheet = wb.createSheet("new Sheet");
  109. //3.创建Excel工作表的行
  110. HSSFRow row = sheet.createRow(6);
  111. //4.创建单元格样式
  112. CellStyle cellStyle =wb.createCellStyle();
  113. // 设置这些样式
  114. cellStyle.setFillForegroundColor(HSSFColor.SKY_BLUE.index);
  115. cellStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
  116. cellStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN);
  117. cellStyle.setBorderLeft(HSSFCellStyle.BORDER_THIN);
  118. cellStyle.setBorderRight(HSSFCellStyle.BORDER_THIN);
  119. cellStyle.setBorderTop(HSSFCellStyle.BORDER_THIN);
  120. cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
  121. //5.创建Excel工作表指定行的单元格
  122. row.createCell(0).setCellStyle(cellStyle);
  123. //6.设置Excel工作表的值
  124. row.createCell(0).setCellValue("aaaa");
  125. row.createCell(1).setCellStyle(cellStyle);
  126. row.createCell(1).setCellValue("bbbb");
  127. //设置sheet名称和单元格内容
  128. wb.setSheetName(0,"第一张工作表");
  129. //设置单元格内容   cell.setCellValue("单元格内容");
  130. // 最后一步,将文件存到指定位置
  131. try
  132. {
  133. FileOutputStream fout = new FileOutputStream("E:/students.xls");
  134. wb.write(fout);
  135. fout.close();
  136. }
  137. catch (Exception e)
  138. {
  139. e.printStackTrace();
  140. }
  141. }
  142. /**
  143. * 创建Excel的实例
  144. * @throws ParseException
  145. */
  146. public static void CreateExcelDemo1() throws ParseException{
  147. List list = new ArrayList();
  148. SimpleDateFormat df = new SimpleDateFormat("yyyy-mm-dd");
  149. Student user1 = new Student(1, "张三", 16,true, df.parse("1997-03-12"));
  150. Student user2 = new Student(2, "李四", 17,true, df.parse("1996-08-12"));
  151. Student user3 = new Student(3, "王五", 26,false, df.parse("1985-11-12"));
  152. list.add(user1);
  153. list.add(user2);
  154. list.add(user3);
  155. // 第一步,创建一个webbook,对应一个Excel文件
  156. HSSFWorkbook wb = new HSSFWorkbook();
  157. // 第二步,在webbook中添加一个sheet,对应Excel文件中的sheet
  158. HSSFSheet sheet = wb.createSheet("学生表一");
  159. // 第三步,在sheet中添加表头第0行,注意老版本poi对Excel的行数列数有限制short
  160. HSSFRow row = sheet.createRow((int) 0);
  161. // 第四步,创建单元格,并设置值表头 设置表头居中
  162. HSSFCellStyle style = wb.createCellStyle();
  163. style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 创建一个居中格式
  164. HSSFCell cell = row.createCell((short) 0);
  165. cell.setCellValue("学号");
  166. cell.setCellStyle(style);
  167. cell = row.createCell((short) 1);
  168. cell.setCellValue("姓名");
  169. cell.setCellStyle(style);
  170. cell = row.createCell((short) 2);
  171. cell.setCellValue("年龄");
  172. cell.setCellStyle(style);
  173. cell = row.createCell((short) 3);
  174. cell.setCellValue("性别");
  175. cell.setCellStyle(style);
  176. cell = row.createCell((short) 4);
  177. cell.setCellValue("生日");
  178. cell.setCellStyle(style);
  179. // 第五步,写入实体数据 实际应用中这些数据从数据库得到,
  180. for (int i = 0; i < list.size(); i++)
  181. {
  182. row = sheet.createRow((int) i + 1);
  183. Student stu = (Student) list.get(i);
  184. // 第四步,创建单元格,并设置值
  185. row.createCell((short) 0).setCellValue((double) stu.getId());
  186. row.createCell((short) 1).setCellValue(stu.getName());
  187. row.createCell((short) 2).setCellValue((double) stu.getAge());
  188. row.createCell((short)3).setCellValue(stu.getSex()==true?"男":"女");
  189. cell = row.createCell((short) 4);
  190. cell.setCellValue(new SimpleDateFormat("yyyy-mm-dd").format(stu
  191. .getBirthday()));
  192. }
  193. // 第六步,将文件存到指定位置
  194. try
  195. {
  196. FileOutputStream fout = new FileOutputStream("E:/students.xls");
  197. wb.write(fout);
  198. fout.close();
  199. }
  200. catch (Exception e)
  201. {
  202. e.printStackTrace();
  203. }
  204. }
  205. }

注意:

修改Excel中的某个内容:

[java] view plain copy

 
  1. cell1.setCellValue("1000");

保存修改后的Excel文件:

[java] view plain copy

 
    1. OutputStream out = new FileOutputStream(file);
    2. wb.write(out);

POI操作Excel详解,HSSF和XSSF两种方式的更多相关文章

  1. POI操作Excel详细解释,HSSF和XSSF两种方式

    HSSF道路: package com.tools.poi.lesson1; import java.io.FileInputStream; import java.io.FileNotFoundEx ...

  2. POI操作Excel详解,读取xls和xlsx格式的文件

    package org.ian.webutil;   import java.io.File; import java.io.FileInputStream; import java.io.FileN ...

  3. Linux 下Redis集群安装部署及使用详解(在线和离线两种安装+相关错误解决方案)

    一.应用场景介绍 本文主要是介绍Redis集群在Linux环境下的安装讲解,其中主要包括在联网的Linux环境和脱机的Linux环境下是如何安装的.因为大多数时候,公司的生产环境是在内网环境下,无外网 ...

  4. Selector、shape详解,注意这两种图像资源都以XML方式存放在drawable不带分辨率的文件夹中

    Selector.shape详解(一) Selector的结构描述: <?xml version="1.0" encoding="utf-8"?> ...

  5. POI操作Excel导入和导出

    Apache的POI组件是Java操作Microsoft Office办公套件的强大API,当中对Word,Excel和PowperPoint都有支持,当然使用较多的还是Excel.由于Word和Po ...

  6. poi操作excel的基本用法

    这周公司要用excel作为数据存储格式做一个文具申请的功能,感觉以前本来很简单的功能变复杂了不少,但是还是记录一下一些excel的基本用法. 写在最前面:这里只介绍一些excel的基本存储方式(读,写 ...

  7. 自己封装的poi操作Excel工具类

    自己封装的poi操作Excel工具类 在上一篇文章<使用poi读写Excel>中分享了一下poi操作Excel的简单示例,这次要分享一下我封装的一个Excel操作的工具类. 该工具类主要完 ...

  8. 自己的包poi操作Excel工具

    在前面的文章<使用poi读写Excel>中分享了一下poi操作Excel的简单演示样例.这次要分享一下我封装的一个Excel操作的工具类. 该工具类主要完毕的功能是:读取Excel.汇总E ...

  9. POI操作Excel(xls、xlsx)

    阿帕奇官网:http://poi.apache.org/ POI3.17下载:http://poi.apache.org/download.html#POI-3.17 POI操作Excel教程(易百教 ...

随机推荐

  1. spring动态数据源+事务

    今天在尝试配置spring的动态数据源和事务管理的时候,遇到了几处配置上的问题,在此记录下: 1.使用了spring的aop思想,实现了动态数据源的切换. 2.spring的事务管理,是基于数据源的, ...

  2. Oracle 导入单表数据

    1. 测试一下 删除某一张表,然后 通过 expdp 数据库泵的备份来恢复数据. 测试过程 ) from bizlog COUNT() ---------- 151 drop table bizlog ...

  3. MySQL查询where条件的顺序对查询效率的影响

    看到有资料说,where条件的顺序会影响查询的效率,根据的逻辑是: where条件的运行是从右到左的,将选择性强的条件放到最右边,可以先过滤掉大部分的数据(而选择性不强的条件过滤后的结果集仍然很大), ...

  4. Grafana elasticsearch 应用

    早期的时候,项目基于ES+echart写了一些仪表盘的展示页面,虽然ES配合这种char界面有着天然的优势,但实际写起代码来,还是很多重复的劳动,在一次偶然中发现Grafana,看到它提供了很多仪表盘 ...

  5. Trips CodeForces - 1037E(思维dfs)

    题意: 就是几个人去旅游,组队的条件是对于某个队员 队里至少有两个是他的朋友,每天早晨都会有一对新人成为朋友 解析: 用set标记互为朋友 a[i] b[i] 表示在第i天早晨 u和v成为朋友 先求最 ...

  6. 开始学习Scheme

    开始学习Scheme   函数式编程(Functional Programming)是在MIT研究人工智能(Artificial Intelligence)时发明的,其编程语言为Lisp.确切地说,L ...

  7. 浅谈平衡树splay

    首先splay和treap不一样,treap通过随机数来调整树的形态.但splay不一样,再每插入或操作一次后,你都会把他旋转到根,再旋转过程中树的形态会不断改变,这样来达到均摊效果 常数据大. 来看 ...

  8. Dom选择器--内容文本操作

    一.文本内容操作 内容: <body> <div id="i1"> 学习是我快乐? <a>晚饭吃什么</a> </div> ...

  9. Helm一:简介

    目录 什么是Helm Helm解决的问题 Helm原理 Helm架构 Helm功能 Helm三个重要概念 Helm组件 Helm Client Tiller Server Helm实现 什么是Helm ...

  10. OpenStack 存储服务 Cinder介绍和控制节点部署(十五)

    Cinder介绍 OpenStack块存储服务(cinder)为虚拟机添加持久的存储,块存储提供一个基础设施为了管理卷,以及和OpenStack计算服务交互,为实例提供卷.此服务也会激活管理卷的快照和 ...