JAVA操作Excel那些事儿

2024-09-01 22:48
文章标签 java excel 操作 事儿

本文主要是介绍JAVA操作Excel那些事儿,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JAVA操作Excel那些事儿


前段时间接了一个Excel的数据处理单子后,小生百度千寻,终于先后使用JXLPOI两个包的后,最终在老师的见一下,使用ODBC访问EXCEL的形式,对处理,对于几种处理EXCEKL的数据方法有了大致的了解和感受,现总结如下:
目标数据:固定格式的EXCEL数据从10W条到100W条不等,根据不同的要求,添加新的记录。即原来一条ABCD数据,变成ABCDE,对于EXCEL的使用上,主要分xls和xlsx2中。
总所周知,xlsx的压缩率比xls提高了不少,而xls每个sheet的数据条数不能超过 65536条,而xlsx的则是 1048576条,所以 过65536条的大数据量xlsx转换成xls时 ,大家可要注意数据会丢失的哦,下附说明图
JAVA操作Excel那些事儿 JAVA操作Excel那些事儿
但是,值得一提的是,在把EXCEL用JAVA读到内存时,相同数据的xls和xlsx 文件,xlsx占的内存要比xls大不少【jxl不支持xlsx的,小生使用xls测试的,ODBC访问未做太多测试】


JXL 官网下载地址:http://sourceforge.net/projects/jxl/

个人网盘分享:

http://pan.baidu.com/share/link?shareid=903370199&uk=1493356468【单纯的jxl包】

http://pan.baidu.com/share/link?shareid=908184674&uk=1493356468【官网下载jxl所有内容,含文档和示例】

JXL 目前只能操作xls版的Excel,但是胜在速度快,而且没什么附加的包,直接导入一个jxl.jar即可。网上也有叫jexcel

jxl中,每个cell读取是都可以用getContents()方法读取,获得的均为String,码农们可以根据需要转换成各种类型。

下附基本代码

public class ReadXLS {

    public static void main(String args[]) {

       try {

           Workbook book = Workbook.getWorkbook(new File("D:\\test.xls "));

           // 获得第一个工作表对象

           Sheet sheet = book.getSheet(0);

           // 得到第一列第一行的单元格

           Cell cell1 = sheet.getCell(0, 0);

           String result = cell1.getContents();

           System.out.println(result);

           book.close();

       }catch(FileNotFoundException e)

       {

           System.out.println("系统找不到指定文件");

       } catch (Exception e) {

           // System.out.println(e);

           e.printStackTrace();

       }

    }

}






POI

官方下载网址:http://poi.apache.org/

个人网盘分享:http://pan.baidu.com/share/link?shareid=912865935&uk=1493356468

dom4j.jar

官方下载网址:http://www.dom4j.org

个人网盘分享:http://pan.baidu.com/share/link?shareid=929504518&uk=1493356468

xbean.jar

官方下载网址:http://xmlbeans.apache.org

个人网盘分享:http://pan.baidu.com/share/link?shareid=938514187&uk=1493356468【单独的jar包】

http://pan.baidu.com/share/link?shareid=940958543&uk=1493356468【官方完整包】

 

POI是一个比较全的类,对于0307版的office均能操作

JAVA操作Excel那些事儿 ,带x的类库就均是操作07的类库

 

其中需要注意的是,sheet在不少包中都有,而我们需要的是

JAVA操作Excel那些事儿

而对于0307的区别上

JAVA操作Excel那些事儿

仅需要在new一个Workbook加以区分即可。

真正需要注意的,调用POI的包时,需要引入各种包,

JAVA操作Excel那些事儿

其中,dom4jxbean.jar是官方包中所没有的,需要自己另外下载。

 

POI中数据类型识别上有了新的划分,原Excel中为数值型的必须用getNumericCellValue()方法获取,返回的为Double型,字符串值的则须用getStringCellValue()获取,否则会出现数值类型不对的Exception,另外可以通过

String d;

                     if(cell.getCellType()!=1)

                     {

                         int date = (int)cell.getNumericCellValue();

                         long timec = (date-25569) * 60 * 24 *60*1000L;

                         SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");

                         d = format.format(timec);

                     }

                     else d = cell.getStringCellValue();

获取cell的类型,其中返回int型的对应的类型如下

CellType 类型

CELL_TYPE_NUMERIC 数值型 0

CELL_TYPE_STRING 字符串型 1

CELL_TYPE_FORMULA 公式型 2

CELL_TYPE_BLANK 空值 3

CELL_TYPE_BOOLEAN 布尔型 4

CELL_TYPE_ERROR 错误 5

JAVA操作Excel那些事儿 改变cell的类型后,在用getStringCellValue(),读取。

 

下附基本代码

 

package cn.com.office.test;

 

import java.io.BufferedReader;

import java.io.FileInputStream;

import java.io.FileOutputStream;

import java.io.IOException;

import java.io.InputStream;

import java.io.InputStreamReader;

import java.io.OutputStream;

 

import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import org.apache.poi.ss.usermodel.Cell;

import org.apache.poi.ss.usermodel.Row;

import org.apache.poi.ss.usermodel.Sheet;

import org.apache.poi.ss.usermodel.Workbook;

import org.apache.poi.xssf.usermodel.XSSFWorkbook;

 

public class TestReadAndWrite {

 

   

    public static void main(String[] args) throws IOException {

       // TODO Auto-generated method stub

       String path = "F:\\";

       String fileName = "存量合计";

       String fileType = "xlsx";

       writer(path,fileName,fileType);

       read(path,fileName,fileType);

       System.out.println("System Stop");

      

    }

 

    private static void writer(String path, String fileName, String fileType) throws IOException{

       // TODO Auto-generated method stub

       Workbook wb = null;

       if(fileType.equals("xls"))

       {

           wb = new HSSFWorkbook();

       }

       else if (fileType.equals("xlsx"))

       {

           wb = new XSSFWorkbook();

       }

       else{

           System.out.println("您的文档格式不正确!");

       }

       Sheet sheet1 = (Sheet)wb.createSheet();

       for(int i = 0; i < 5; i++)

       {

           Row row = (Row)sheet1.createRow(i);

           for(int j = 0; j < 8 ; j++)

           {

              Cell cell = row.createCell(j);

              cell.setCellValue(i);

           }

       }

       OutputStream stream = new FileOutputStream(path + fileName + "." + fileType);

       wb.write(stream);

       stream.close();

    }

 

    private static void read(String path, String fileName, String fileType)throws IOException {

       // TODO Auto-generated method stub

       InputStream stream = new FileInputStream(path + fileName + "." + fileType);

       Workbook wb = null;

       if(fileType.equals("xls"))

       {

           wb = new HSSFWorkbook(stream);

       }

       else if (fileType.equals("xlsx"))

       {

           wb = new XSSFWorkbook(stream);

       }else{

           System.out.println("您的文档格式不正确!");

       }

    Sheet sheet1 = wb.getSheetAt(0);

       for(Row row2:sheet1)

       {

           for(Cell cell2:row2){

              System.out.print((int)cell2.getNumericCellValue() + "");

           }

           System.out.println();

          

    }

 

}





用微软的ODBC的连接Excel从而实现操作,着实让我眼前一亮,但配置方面却,让我比较无语,在用ODBC连接Excel前需要实现配置驱动,具体操作如下

控制面变->管理工具->ODBC 数据源 –>系统DSN->添加->Microsoft Excel Driver(*.xls, *.xlsx*.xlsm, *.xlsb),添加的时候,数据源名称类同数据库名

这边设定的时候就会出现64位系统和32系统的差别


JAVA操作Excel那些事儿这是我本机中两个ODBC 数据源,但是

32位中有相应的驱动,而64位的系统中却没有

JAVA操作Excel那些事儿

度娘后,有说ODBC连接office 不支持64的操作系统,

 

如果数据管理工具中没有ODBC 数据源(32 ) 用虚拟机搭个32位的系统吧0.0或者直接装32位的office

 

具体的代码如下

import java.sql.Connection;

 

import java.sql.DriverManager;

 

import java.sql.ResultSet; 

import java.sql.SQLException;

import java.sql.Statement;

 public class test9 {

        

         public static void main(String[] args) {

                  // TODO Auto-generated method stub

                   try{

                            Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");

                            Connection conn = DriverManager.getConnection("jdbc:odbc:DB;DBQ=D:\\test.xls");

                            Statement stmt = conn.createStatement();

                   //      int rs = stmt.executeUpdate("INSERT INTO [sheet1$] values (12,'xinli',21, 22);");

                   //      System.out.println(rs);

                            ResultSet rs = stmt.executeQuery("SELECT * FROM [sheet1$]");

while(rs.next())

{

         System.out.println(rs.getString(1));

}

                            stmt.close();

                            conn.close();

                   }

                   catch(SQLException e){

                            e.printStackTrace();

                            System.out.println("");

                   } catch (ClassNotFoundException e) {

                            // TODO Auto-generated catch block

                            System.out.println("");

                   }

         }

}

 

不难发现

除了加载驱动的时候用Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");

连接中Connection conn = DriverManager.getConnection("jdbc:odbc:DB;DBQ=D:\\test.xls");

DB为数据库名,即之前添加驱动的时候所用的名字,DBQ=后面部分则是需要操作的Excel文件的路径。

其他部分均与JDBC相同,表名即为sheet名,但需表示[sheet1$],另外所有SQL部分与Access相同,但是不方便用limit语句,而小生也为接触过Access,一切以MySQL语句撰写,大部均可以使用,

Excel表的第一行,默认为表的字段~

这篇关于JAVA操作Excel那些事儿的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1128265

相关文章

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Java实现检查多个时间段是否有重合

《Java实现检查多个时间段是否有重合》这篇文章主要为大家详细介绍了如何使用Java实现检查多个时间段是否有重合,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录流程概述步骤详解China编程步骤1:定义时间段类步骤2:添加时间段步骤3:检查时间段是否有重合步骤4:输出结果示例代码结语作

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Java判断多个时间段是否重合的方法小结

《Java判断多个时间段是否重合的方法小结》这篇文章主要为大家详细介绍了Java中判断多个时间段是否重合的方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录判断多个时间段是否有间隔判断时间段集合是否与某时间段重合判断多个时间段是否有间隔实体类内容public class D

IDEA编译报错“java: 常量字符串过长”的原因及解决方法

《IDEA编译报错“java:常量字符串过长”的原因及解决方法》今天在开发过程中,由于尝试将一个文件的Base64字符串设置为常量,结果导致IDEA编译的时候出现了如下报错java:常量字符串过长,... 目录一、问题描述二、问题原因2.1 理论角度2.2 源码角度三、解决方案解决方案①:StringBui

Java覆盖第三方jar包中的某一个类的实现方法

《Java覆盖第三方jar包中的某一个类的实现方法》在我们日常的开发中,经常需要使用第三方的jar包,有时候我们会发现第三方的jar包中的某一个类有问题,或者我们需要定制化修改其中的逻辑,那么应该如何... 目录一、需求描述二、示例描述三、操作步骤四、验证结果五、实现原理一、需求描述需求描述如下:需要在

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.