jacob方式,java实现excel的写数据过程

2024-02-04 22:08

本文主要是介绍jacob方式,java实现excel的写数据过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

配置:1,将jacob.jar导入到工程的classpath下 2,把jacob.dll文件拷贝到jdk/bin目录下

package excelTest1;

import com.jacob.activeX.ActiveXComponent;
import com.jacob.com.Dispatch;
import com.jacob.com.Variant;


public class JacobExcelSample {
 private static ActiveXComponent xl;
 private static Dispatch workbooks = null;//
 private static Dispatch workbook = null;
 private static Dispatch currentSheet = null;// 当前sheet
 private static Dispatch sheets = null;// 获得sheets集合对象
 private static Dispatch sheet = null;// 未活动sheet

 private static String filename = null;
 private static boolean readonly = false;

 public static void main(String[] args) {
  String file = "D://workcontent//excel//jacobExcel.xls";
  OpenExcel(file, true);// false为不显示打开Excel
  addSheet();// 添加sheet
  modifySheetName("new sheet name8");// 修改当前sheet的名字
  setValue("A1", "Value", "2");//设值

  System.out.println("currentSheet的名字:"+getSheetName());// 得到工作薄的名字
  System.out.println("workbook的名字:"+getWorkbookName());// 得到工作薄的名字
  System.out.println("sheet的总数:" + getSheetCount());
  System.out.println("当前sheet的A1位置的值:" + getValue("A1", currentSheet));
  CloseExcel(false);
 }

 // 添加新的工作表(sheet),(添加后为默认为当前激活的工作表)
 private static void addSheet() {
  Dispatch.get(Dispatch.get(workbook, "sheets").toDispatch(), "add");
 }

 // 修改当前工作表的名字
 private static void modifySheetName(String newName) {
  Dispatch.put(getCurrentSheet(), "name", newName);
 }
 
 // 得到当前工作表的名字
 private static String getSheetName() {
  return Dispatch.get(currentSheet, "name").toString();
 }
 
 // 得到工作薄的名字
 private static String getWorkbookName() {
  return Dispatch.get(workbook, "name").toString();
 }

 // 得到sheets的集合对象
 private static Dispatch getSheets() {
  sheets = Dispatch.get(workbook, "sheets").toDispatch();
  return sheets;
 }

 // 通过工作表名字得到工作表(未实现)
 private static Dispatch getSheetByName(String name) {
  //
  return sheet;
 }
 // 通过工作表索引得到工作表(未实现)
 private static Dispatch getSheetByIndex(String name) {
  //
  return sheet;
 }

 // 得到当前sheet
 private static Dispatch getCurrentSheet() {
  currentSheet = Dispatch.get(workbook, "ActiveSheet").toDispatch();
  return currentSheet;
 }

 // 得到sheet的总数
 private static int getSheetCount() {
  int count = Dispatch.get(getSheets(), "count").toInt();
  return count;
 }

 // // 写入值
 private static void setValue(String position, String type, String value) {

  Dispatch cell = Dispatch.invoke(getCurrentSheet(), "Range",
    Dispatch.Get, new Object[] { position }, new int[1])
    .toDispatch();
  Dispatch.put(cell, type, value);
 }


 // 读取值
 private static String getValue(String position, Dispatch currentSheet) {
  Dispatch cell = Dispatch.invoke(currentSheet, "Range", Dispatch.Get,
    new Object[] { position }, new int[1]).toDispatch();
  String value = Dispatch.get(cell, "Value").toString();
  return value;
 }

 // 打开Excel文档
 private static void OpenExcel(String file, boolean f) {
  try {
   filename = file;
   xl = new ActiveXComponent("Excel.Application");
   xl.setProperty("Visible", new Variant(f));
   workbooks = xl.getProperty("Workbooks").toDispatch();
   workbook = Dispatch.invoke(
     workbooks,
     "Open",
     Dispatch.Method,
     new Object[] { filename, new Variant(false),
       new Variant(readonly) },// 是否以只读方式打开
     new int[1]).toDispatch();
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

 // 关闭Excel文档
 private static void CloseExcel(boolean f) {
  try {
   Dispatch.call(workbook, "Save");
   Dispatch.call(workbook, "Close", new Variant(f));
  } catch (Exception e) {
   e.printStackTrace();
  } finally {
   xl.invoke("Quit", new Variant[] {});
  }
 }

 

//以上有两个地方没有实现,希望知道的朋友,留个言,最好把代码附上,非常感谢!

这篇关于jacob方式,java实现excel的写数据过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

一文详解SpringBoot中控制器的动态注册与卸载

《一文详解SpringBoot中控制器的动态注册与卸载》在项目开发中,通过动态注册和卸载控制器功能,可以根据业务场景和项目需要实现功能的动态增加、删除,提高系统的灵活性和可扩展性,下面我们就来看看Sp... 目录项目结构1. 创建 Spring Boot 启动类2. 创建一个测试控制器3. 创建动态控制器注

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

C#读写文本文件的多种方式详解

《C#读写文本文件的多种方式详解》这篇文章主要为大家详细介绍了C#中各种常用的文件读写方式,包括文本文件,二进制文件、CSV文件、JSON文件等,有需要的小伙伴可以参考一下... 目录一、文本文件读写1. 使用 File 类的静态方法2. 使用 StreamReader 和 StreamWriter二、二进

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

在Linux中改变echo输出颜色的实现方法

《在Linux中改变echo输出颜色的实现方法》在Linux系统的命令行环境下,为了使输出信息更加清晰、突出,便于用户快速识别和区分不同类型的信息,常常需要改变echo命令的输出颜色,所以本文给大家介... 目python录在linux中改变echo输出颜色的方法技术背景实现步骤使用ANSI转义码使用tpu

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp