9

我最近发现了 py4j 并且能够从 python 调用静态 java 方法。现在我想从 java 调用 python 方法。我找不到太多文档,所以这是我能想到的最后一个地方,它可能会告诉我它是否可能,以及如何。

4

1 回答 1

10

您可以通过在 python 端实现 Java 接口从 Java 调用 Python 方法。

步骤是:

  1. 在 Java 中创建一个接口,例如 py4j.examples.Operator
  2. 在 Python 中,创建一个类并在该类内部创建一个带有“implements”字段的 Java 类。
  3. 在 Python 中,使用 start_callback_server=True 实例化网关,例如,gateway = JavaGateway(start_callback_server=True)
  4. 在 Python 中,实例化实现 Java 接口的类并将其发送到 Java 端。
  5. 在 Java 中,调用接口。

改编自 Py4J 文档的示例:

Java代码:

// File 1
package py4j.examples;

public interface Operator {
        public int doOperation(int i, int j);
        public int doOperation(int i, int j, int k);
}

// File 2
package py4j.examples;

import java.util.ArrayList;
import java.util.List;
import java.util.Random;

import py4j.GatewayServer;

public class OperatorExample {

    // To prevent integer overflow
    private final static int MAX = 1000;

    public List<Integer> randomBinaryOperator(Operator op) {
        Random random = new Random();
        List<Integer> numbers = new ArrayList<Integer>();
        numbers.add(random.nextInt(MAX));
        numbers.add(random.nextInt(MAX));
        numbers.add(op.doOperation(numbers.get(0), numbers.get(1)));
        return numbers;
    }
}

Python代码:

from py4j.java_gateway import JavaGateway

class Addition(object):
    def doOperation(self, i, j, k = None):
        if k == None:
            return i + j
        else:
            return i + j + k

    class Java:
        implements = ['py4j.examples.Operator']

if __name__ == '__main__':
    gateway = JavaGateway(start_callback_server=True)
    operator = Addition()
    operator_example = gateway.jvm.py4j.examples.OperatorExample()

    # "Sends" python object to the Java side.
    numbers = operator_example.randomBinaryOperator(operator) 
于 2014-04-19T12:44:07.877 回答