Jpype调用jar包"Class xx not found"问题

前置环境

  • Java 1.8 (64位)
  • Python 2.7.9 (32位)
  • Jpype 0.5.4.2
  • Pycharm

代码

import jpype
from jpype import *

# 该目录下有需要调用的jar包 pak.jar
jvmArg = "-Djava.ext.dirs=D:/1_Workspace/jpype_test/"
if not jpype.isJVMStarted():
     jvmPath = jpype.getDefaultJVMPath()
     jpype.startJVM(jvmPath,"-ea", jvmArg)
     # pak.jar中包含类com.abc.EFG
     jd = JClass("com.abc.EFG")
     instance = jd()
     print(instance.getName())
     jpype.shutdownJVM()

问题

执行以上代码,报错如下。Class com.abc.EFG not found
Jpype调用jar包

分析

1.可以肯定在pak.jar包中有com.abc.EFG这个类

2.EFG依赖的jar包都在同级目录下

3.可以肯定Jpype使用没有问题,因为调用java的System.out.println可以打印

jprint = java.lang.System.out.println
jprint("xxx") #输出xxx

试着从环境上找原因,也许和Java版本有关吧

首先查找pak.jar包的编译jdk版本,方法参见链接:

https://blog.csdn.net/sweettool/article/details/77203193

使用以上方法获得输出是 52,即对应java 1.8,与本机Java版本相符。
但是回头一想其实在Pycharm中并没有配置过Java使用的版本

那么试着打印一下jvmPath,获得的路径是C:\Program Files (x86)\Java\jre6\bin\client\jvm.dll
使用的是系统自带的 jre1.6(32位)

由于jar包是1.8的,试着将代码中获取JVMPath的方法直接修改成jre1.8jvm文件路径。
此时去Java目录找,发现虽然有jvm.dll,但并不是在client目录,而是在server目录下。

# jvmPath = jpype.getDefaultJVMPath()
jvmPath = r'D:\java\jdk1.8\jre\bin\server\jvm.dll'

修改后再次执行,还是报同样错误。

解决

最后装了jdk1.8 32位!!!,发现在client目录下有jvm.dll文件了
再次修改,执行通过。
run successfully


总结

过于坑 真神奇

你可能感兴趣的:(Python)