不会吧,还有人不会用 Java 的 Excel 导入导出??

2021-01-13 18:00:38 +08:00
 xiaTianChiXiGua

标题党了, 各位,老项目中使用的 POI 是 3.9 版本,现在想要使用 easyExcel,它最低引入的是 3.17 的 POI,如何两个 jar 包共存呐?求各位指点一下

3396 次点击
所在节点    Java
20 条回复
fiveelementgid
2021-01-13 18:03:43 +08:00
不会吧,不会吧,不会还有人在这问而不是自己去翻 document 吧。
xiaTianChiXiGua
2021-01-13 18:06:04 +08:00
@fiveelementgid 真没招了 搞了两天了 没搞定
crazyxtcn
2021-01-13 18:10:10 +08:00
这个我遇到过,POI 各个版本之间改动挺大的,当时两个 jar 依赖了不同版本的 poi,不管怎么调,运行时都会遇到 NoSuchMethod 之类的异常,最后用原生 poi 手写的导出
xiaTianChiXiGua
2021-01-13 18:13:07 +08:00
@crazyxtcn 我看了一下如果 3.9 升级到 3.17 项目里要替换不少的代码,一不小心就要出 bug 。。 如果继续用老版本的 POI,又感觉有点恶心 想试试 easyexcel
optional
2021-01-13 18:13:48 +08:00
别试了,不太好用
xiaTianChiXiGua
2021-01-13 18:14:50 +08:00
@optional 继续用 POI 老版本写代码?
xcstream
2021-01-13 18:21:49 +08:00
恭喜你发现了个 java 的硬伤
redtea
2021-01-13 18:28:01 +08:00
方案一:自定义 ClassLoader 加载 jar
方案二:改造成微服务调用
c2const
2021-01-13 18:38:59 +08:00
2333,从安全角度给你支个招,用 zkm 之类的混淆软件去把新版本的 POI jar 包的依赖全部混淆,本身对外接口(函数名、类名)都不变,最后再把 x.y.A.class 改成 x2.y.A.class 之类避免冲突,类似 c 艹的 namespace 一样,避免调用冲突。
purensong
2021-01-13 18:43:53 +08:00
问个问题还阴阳怪气的,建议多看看别人怎么问的
nl101531
2021-01-13 18:45:12 +08:00
这种只能隔离。。。一个 jar 脱离 maven,使用单独的类加载器加载执行
qwerthhusn
2021-01-13 18:49:12 +08:00
找个工具,把高版本的 jar 包的包名完全改了。导入到私服
wander639
2021-01-13 20:46:01 +08:00
不会吧,看这个标题还以为是写教程的
darksword21
2021-01-13 20:54:38 +08:00
这种标题在虎扑那看得想骂人,建议不要在这里搞
iamaprin
2021-01-13 21:26:27 +08:00
手动打包 easyexcel 源码,修改 pom.xml ,打 shade 包,关键字 class relocation 。
Takamine
2021-01-13 21:36:32 +08:00
pandas, csv, xlrd 它不香吗。
lucahan
2021-01-13 21:49:09 +08:00
不会吧,除了虎扑还真有人用这种标题
czzhengkw
2021-01-13 21:51:54 +08:00
不会吧,这样问问题不会被打吗?
SkyLine7
2021-01-14 08:35:39 +08:00
小丑竟是我自己
xiaTianChiXiGua
2021-01-14 08:41:38 +08:00
@darksword21 看来不少虎扑老哥啊 哈哈

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/744650

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX