不开源项目aspose.cells最新版23.10的一些科普

2023-10-25 17:28

本文主要是介绍不开源项目aspose.cells最新版23.10的一些科普,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.基本介绍

日常工作中我们常常会使用到Excel来做一些事情,也常常需要使用代码程序来解析Excel文件,目前来说对于poi、easypoi、easyexcel、jxls的使用已经非常多了,它们都在一些特定情况下很好的去处理Excel文件,但有些时候我们要解析的Excel不是标准的xls、xlsx格式的文件,但是可以使用Excel或WPS正常打开,特别是WPS兼容的特别好,对于一些html、xml的源文件,只要后缀为xls、xlsx格式,它总是直接打开了,在Office Excel中打开时还会有非标准Excel文件打开时的确认提示框。对于那些非标准格式的Excel文件(可能是业余选手用代码生成的,也有可能是使用Excel另存为html、xml等格式,又手工修改为xls的情况),以前我坚决的对这部分文件选择了不处理。

上次在编写一个大范围解析Excel文件的功能时,这种不规范的Excel文件实在是多,所以不得不面对这种问题,经过一番尝试发现自己解析html的方式太复杂了,变化多样,而且还不支持另存为xml的格式的文件,于是也在旁边少年的提醒下尝试着使用了`aspose.cells`的试用版本,它在格式转换、生成Excel时会生成多余的一个Sheet页《Evaluation Warning》,参考如下图所示:

image.png

所以最终采用的实现就是用它来转换一下格式,实际上它的格式转换代码使用比较简单,功能强大,支持的文件格式有很多中,常见的有:html、xml、csv等多种,参考如下代码将一段html表格页面表格转换为Excel文件,返回Workbook对象:

public static void main(String[] args) throws Exception {String html ="<html>" +"<head>" +"<title>https://www.chendd.cn</title>" +"</head>" +"<body>" +"<table>" +"<tr><td>1</td><td>2</td><td>3</td><td>4</td><td>5</td></tr>" +"<tr><td>6</td><td>7</td><td>8</td><td>9</td><td>10</td></tr>" +"</table>" +"</bod>" +"</html>";System.out.println("aspose.cells version:" + CellsHelper.getVersion());Workbook workbook = new Workbook(new ByteArrayInputStream(html.getBytes()));//格式另存workbook.save("output.csv", SaveFormat.CSV);workbook.save("output.xls", SaveFormat.EXCEL_97_TO_2003);workbook.save("output.xlsx", SaveFormat.XLSX);workbook.save("output.pdf", SaveFormat.PDF);
}

格式转换后返回的是`Workbook`对象,它不是poi的API中的`Workbook`,实际上save函数可以传递OutputStream流对象,所以后续的解析可以使用poi的Workbook对象来解析OutputStream流即可。

2.其它说明

(1)`aspose.cells`不是开源免费的使用,有试用版本,试用的结果就是生成了一些《Evaluation Warning》警告;

(2)maven中央仓库 https://mvnrepository.com 中只有8.2.1版本的aspose.cells版本,是2015年的版本;

(3)aspose旗下有许多的产品,都是商业付费版本,常见的还有操作word的,与cells一样不开源,需要商业授权使用,单说cells组件支持不同的开发语言,有Java、C++、.NET等等,除了核心组件外也提供了一个web版本,貌似是用作于浏览器在线版本的Excel处理组件,官方地址:Aspose.Cells | Excel Spreadsheet Processing Java Library;

(4)截至今日2023年10月24,该组件最新 Release 版本为`aspose-cells-23.10.jar`是2023年10月14日发布;

3.旧版使用

(1)最新版本才发布俩礼拜,,网络上也没有找到一些激(破)活(解)版,针对于反编译混淆代码的阅读,难度非常大,期待有大佬的出现;

(2)从gitee上找到了一位大佬的学习实践教程,作者研究了aspose.cells的 20.7 的版本,距离最新版本发布相距 3 年多近 40 个Release版本,可参考:https://gitee.com/evilrule/crack-aspose,有需要旧版的可以移步查阅和实践,确实可以把《Evaluation Warning》警告去除;

(3)仅供学习,不可用于商业用途,给个gitee上项目的

截图说明,防止找不到了,尝试了一下setLicense只触发一次即可,通常可以写一个工具类,把调用逻辑放置在static静态块中即可;

4.新版学习

学习有许多种,除了可以学习组件的API使用外,也可以学习一下 20.7 版本激活大佬的钻研精神,所以在一系列的失败尝试后,最终终于激活 aspose-cells-23.10.jar 成功,以下是学习过程:

(1)参考 20.7 版本大佬使用的 javassist 字节码框架,本站有相关的文章示例,曾经略微学习过该框架;

(2)按照 20.7 版本大佬提供的方向重点关注 `com.aspose.cells.License` 类,里面的方法 isLicenseSet 可以理解为是否设置 License,将其修改为 true;方法 getSubscriptionExpireDate 可以理解为获取过期时间,将其修改为 2099 年;方法 a 可以看到是在转换日期格式,将其修改为当前日期;

(3)由于使用的是`Workbook`对象的工具类,将其中的对象方法 isLicensed 修改为 true;

(4)以上的几种尝试均失败,不过最终的结果是成功的,精简后的改动非常非常的小,完全可以不需要调整 License 类,对于这种最新版本的API尝试只是验证了本篇文章所述的示例,即将 html 代码转换为 csv、xls、xlsx、pdf 四种格式;

(5)本篇文章主要是简单科普一下`aspose.cells`组件的介绍,相关内容请勿用于商业用途,如有带来任何问题,均与本篇文章作者无关(请勿用于商业用途、请勿用于商业用途、请勿用于商业用途)

(6)欢迎在本站留言交流,最后附上代码运行效果图,参考如下:

运行效果预览.gif

(激活版精简图)

运行效果预览-原版精简.gif

(原始版精简图)

不开源项目aspose.cells的一些科普欢迎来到陈冬冬的个人经验分享平台icon-default.png?t=N7T8https://www.chendd.cn/blog/article/1716713331426598913.html如有任何问题请在上述原文里留言。

这篇关于不开源项目aspose.cells最新版23.10的一些科普的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

在cscode中通过maven创建java项目

在cscode中创建java项目 可以通过博客完成maven的导入 建立maven项目 使用快捷键 Ctrl + Shift + P 建立一个 Maven 项目 1 Ctrl + Shift + P 打开输入框2 输入 "> java create"3 选择 maven4 选择 No Archetype5 输入 域名6 输入项目名称7 建立一个文件目录存放项目,文件名一般为项目名8 确定

金融业开源技术 术语

金融业开源技术  术语 1  范围 本文件界定了金融业开源技术的常用术语。 本文件适用于金融业中涉及开源技术的相关标准及规范性文件制定和信息沟通等活动。

安全管理体系化的智慧油站开源了。

AI视频监控平台简介 AI视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。用户只需在界面上进行简单的操作,就可以实现全视频的接入及布控。摄像头管理模块用于多种终端设备、智能设备的接入及管理。平台支持包括摄像头等终端感知设备接入,为整个平台提

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

SpringBoot项目是如何启动

启动步骤 概念 运行main方法,初始化SpringApplication 从spring.factories读取listener ApplicationContentInitializer运行run方法读取环境变量,配置信息创建SpringApplication上下文预初始化上下文,将启动类作为配置类进行读取调用 refresh 加载 IOC容器,加载所有的自动配置类,创建容器在这个过程

Maven创建项目中的groupId, artifactId, 和 version的意思

文章目录 groupIdartifactIdversionname groupId 定义:groupId 是 Maven 项目坐标的第一个部分,它通常表示项目的组织或公司的域名反转写法。例如,如果你为公司 example.com 开发软件,groupId 可能是 com.example。作用:groupId 被用来组织和分组相关的 Maven artifacts,这样可以避免