3

通过打开我的 Java 程序,然后使用以下 Python 代码,我可以在 Python 中与我的示例 Java 程序进行交互:

from py4j.java_gateway import JavaGateway
gg = JavaGateway()
sw = gg.entry_point.getInstance()
sw.run()
...

然而,这有一个缺点,即我必须在使用此代码之前以某种方式打开 Java 程序。

我发现有一个名为 launch_gateway 的方法似乎非常方便实现这一目标。

py4j.java_gateway.launch_gateway(jarpath="path_to_my_jar.jar")

但是,如果以这种方式启动,我将无法连接到我的 Java 程序。

我尝试使用以下代码:

port = py4j.java_gateway.launch_gateway(jarpath="path_to_my_jar.jar")
gp = GatewayParameters(port=port) 
gg = JavaGateway(gateway_parameters=gp)
sw = gg.entry_point.getInstance()

但我收到以下错误:

An error occurred while calling t.getInstance. Trace:
py4j.Py4JException: Target Object ID does not exist for this gateway :t

我想我在尝试连接到网关的方式上做错了。

有什么建议吗?

谢谢

4

2 回答 2

7

巴泰勒米,你是对的!我最初误解了这是如何工作的。

launch_gateway在 py4j.jar 中运行网关,这对于与标准 JVM 交互很有用,但显然不包含自定义代码。

但是,正如您所建议的,该classpath参数允许您加载其他自定义 Java 代码。

这是一个“最小的例子”:

from py4j.java_gateway import JavaGateway 
gg = JavaGateway.launch_gateway(classpath="/path/my_jar.jar")

myclass_instance = gg.jvm.my_class_package_name.MyClass()
result = myclass_instance.my_method()

请注意,my_jar.jar不必启动网关。

launch_gateway为您提供不错的功能,例如:die_on_exit、stdout/stdin 重定向和自动端口选择。

于 2017-03-17T21:48:29.037 回答
1

我看到两个潜在的问题:

  1. jarpath 应该是 Py4J 的 jar 的路径。您可以在launch_gateway 的类路径参数中添加您的库。
  2. 当您从 launch_gateway 启动 py4j.GatewayServer 时,确实没有指定入口点,entry_point 确实如此
于 2017-03-17T07:52:28.237 回答