环境
- 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
检查点
1.在pak.jar包中有com.abc.EFG
类
2.EFG
依赖的jar包都在同级目录下
3.Jpype使用没有问题:调用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位)。
此时去Java1.8目录找,发现server
目录下有jvm.dll
,不是在client
目录。管他的,尝试直接指定存在的jvm.dll路径。
# ...
# jvmPath = jpype.getDefaultJVMPath()
jvmPath = r'D:\java\jdk1.8\jre\bin\server\jvm.dll'
jpype.startJVM(jvmPath,"-ea", jvmArg)
# ...
到这里也许有人的问题可以解决了,但我的情况是还是报错…
解决
最后装了jdk1.8 32位!!!,发现在client
目录下有jvm.dll
文件了
再次修改代码,执行通过。
总结
过于坑 真神奇