【类库教程】Java 实现导出 excel 表 POI

本贴最后更新于 1917 天前,其中的信息可能已经时异事殊

Java 实现导出 excel 表 POI

1.首先下载 poi-3.6-20091214.jar,下载地址如下:

http://download.csdn.net/download/qq_31635851/10026048

官网地址:http://poi.apache.org/

2.Student.java

  import java.util.Date;  
    
  public class Student  
  {  
      private int id;  
      private String name;  
      private int age;  
      private Date birth;  
    
      public Student()  
      {  
      }  
    
      public Student(int id, String name, int age, Date birth)  
      {  
          this.id = id;  
          this.name = name;  
          this.age = age;  
          this.birth = birth;  
      }  
    
      public int getId()  
      {  
          return id;  
      }  
    
      public void setId(int id)  
      {  
          this.id = id;  
      }  
    
      public String getName()  
      {  
          return name;  
      }  
    
      public void setName(String name)  
      {  
          this.name = name;  
      }  
    
      public int getAge()  
      {  
          return age;  
      }  
    
      public void setAge(int age)  
      {  
          this.age = age;  
      }  
    
      public Date getBirth()  
      {  
          return birth;  
      }  
    
      public void setBirth(Date birth)  
      {  
          this.birth = birth;  
      }  
    
  }  

3.CreateSimpleExcelToDisk.java

  import java.io.FileOutputStream;  
  import java.text.SimpleDateFormat;  
  import java.util.ArrayList;  
  import java.util.List;  
    
  import org.apache.poi.hssf.usermodel.HSSFCell;  
  import org.apache.poi.hssf.usermodel.HSSFCellStyle;  
  import org.apache.poi.hssf.usermodel.HSSFRow;  
  import org.apache.poi.hssf.usermodel.HSSFSheet;  
  import org.apache.poi.hssf.usermodel.HSSFWorkbook;  
    
  public class CreateSimpleExcelToDisk  
  {  
      /** 
       * @功能:手工构建一个简单格式的Excel 
       */  
      private static List getStudent() throws Exception  
      {  
          List list = new ArrayList();  
          SimpleDateFormat df = new SimpleDateFormat("yyyy-mm-dd");  
    
          Student user1 = new Student(1, "张三", 16, df.parse("1997-03-12"));  
          Student user2 = new Student(2, "李四", 17, df.parse("1996-08-12"));  
          Student user3 = new Student(3, "王五", 26, df.parse("1985-11-12"));  
          list.add(user1);  
          list.add(user2);  
          list.add(user3);  
    
          return list;  
      }  
    
      public static void main(String[] args) throws Exception  
      {  
          // 第一步,创建一个webbook,对应一个Excel文件  
          HSSFWorkbook wb = new HSSFWorkbook();  
          // 第二步,在webbook中添加一个sheet,对应Excel文件中的sheet  
          HSSFSheet sheet = wb.createSheet("学生表一");  
          // 第三步,在sheet中添加表头第0行,注意老版本poi对Excel的行数列数有限制short  
          HSSFRow row = sheet.createRow((int) 0);  
          // 第四步,创建单元格,并设置值表头 设置表头居中  
          HSSFCellStyle style = wb.createCellStyle();  
          style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 创建一个居中格式  
    
          HSSFCell cell = row.createCell((short) 0);  
          cell.setCellValue("学号");  
          cell.setCellStyle(style);  
          cell = row.createCell((short) 1);  
          cell.setCellValue("姓名");  
          cell.setCellStyle(style);  
          cell = row.createCell((short) 2);  
          cell.setCellValue("年龄");  
          cell.setCellStyle(style);  
          cell = row.createCell((short) 3);  
          cell.setCellValue("生日");  
          cell.setCellStyle(style);  
    
          // 第五步,写入实体数据 实际应用中这些数据从数据库得到,  
          List list = CreateSimpleExcelToDisk.getStudent();  
    
          for (int i = 0; i < list.size(); i++)  
          {  
              row = sheet.createRow((int) i + 1);  
              Student stu = (Student) list.get(i);  
              // 第四步,创建单元格,并设置值  
              row.createCell((short) 0).setCellValue((double) stu.getId());  
              row.createCell((short) 1).setCellValue(stu.getName());  
              row.createCell((short) 2).setCellValue((double) stu.getAge());  
              cell = row.createCell((short) 3);  
              cell.setCellValue(new SimpleDateFormat("yyyy-mm-dd").format(stu  
                      .getBirth()));  
          }  
          // 第六步,将文件存到指定位置  
          try  
          {  
              FileOutputStream fout = new FileOutputStream("E:/students.xls");  
              wb.write(fout);  
              fout.close();  
          }  
          catch (Exception e)  
          {  
              e.printStackTrace();  
          }  
      }  
  }  
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3167 引用 • 8207 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
moonce
宠辱不惊,看庭前花开花落,去留无意,望天上云卷云舒。

推荐标签 标签

  • BND

    BND(Baidu Netdisk Downloader)是一款图形界面的百度网盘不限速下载器,支持 Windows、Linux 和 Mac,详细介绍请看这里

    107 引用 • 1281 回帖 • 19 关注
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    22 引用 • 31 回帖 • 3 关注
  • 宕机

    宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。

    13 引用 • 82 回帖 • 37 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 23 关注
  • 心情

    心是产生任何想法的源泉,心本体会陷入到对自己本体不能理解的状态中,因为心能产生任何想法,不能分出对错,不能分出自己。

    59 引用 • 369 回帖
  • CSS

    CSS(Cascading Style Sheet)“层叠样式表”是用于控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。

    180 引用 • 447 回帖 • 1 关注
  • Telegram

    Telegram 是一个非盈利性、基于云端的即时消息服务。它提供了支持各大操作系统平台的开源的客户端,也提供了很多强大的 APIs 给开发者创建自己的客户端和机器人。

    5 引用 • 35 回帖
  • frp

    frp 是一个可用于内网穿透的高性能的反向代理应用,支持 TCP、UDP、 HTTP 和 HTTPS 协议。

    15 引用 • 7 回帖 • 9 关注
  • PWA

    PWA(Progressive Web App)是 Google 在 2015 年提出、2016 年 6 月开始推广的项目。它结合了一系列现代 Web 技术,在网页应用中实现和原生应用相近的用户体验。

    14 引用 • 69 回帖 • 132 关注
  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    18598 引用 • 69218 回帖
  • sts
    2 引用 • 2 回帖 • 146 关注
  • SQLServer

    SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。

    19 引用 • 31 回帖 • 3 关注
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖
  • InfluxDB

    InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

    2 引用 • 53 关注
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 43 关注
  • 自由行
    1 关注
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 633 关注
  • Vditor

    Vditor 是一款浏览器端的 Markdown 编辑器,支持所见即所得、即时渲染(类似 Typora)和分屏预览模式。它使用 TypeScript 实现,支持原生 JavaScript、Vue、React 和 Angular。

    311 引用 • 1666 回帖
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    4 引用 • 7 回帖
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    17 引用 • 236 回帖 • 420 关注
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    164 引用 • 407 回帖 • 526 关注
  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 621 关注
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖 • 1 关注
  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 383 回帖 • 3 关注
  • 锤子科技

    锤子科技(Smartisan)成立于 2012 年 5 月,是一家制造移动互联网终端设备的公司,公司的使命是用完美主义的工匠精神,打造用户体验一流的数码消费类产品(智能手机为主),改善人们的生活质量。

    4 引用 • 31 回帖 • 11 关注
  • OAuth

    OAuth 协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是 oAuth 的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此 oAuth 是安全的。oAuth 是 Open Authorization 的简写。

    36 引用 • 103 回帖 • 6 关注
  • 大数据

    大数据(big data)是指无法在一定时间范围内用常规软件工具进行捕捉、管理和处理的数据集合,是需要新处理模式才能具有更强的决策力、洞察发现力和流程优化能力的海量、高增长率和多样化的信息资产。

    89 引用 • 113 回帖