【Python】Python调用Java jar包方式 ——Jpype使用

3 篇文章 1 订阅
这篇博客演示了如何使用Python通过Jpype库调用Java编写的Jieba分词Jar包。首先创建了一个Java程序,引入jieba-analysis依赖并打包成jar。接着在Python环境中,安装Jpype并初始化Java虚拟机,最后成功调用Java方法进行分词操作。这是一个关于跨语言交互和自然语言处理的实例。
摘要由CSDN通过智能技术生成

背景

有些时候,项目中已经有现场功能的包,但是相关的包使用Java开发的。为了能够减少Java转Python的时间,我们可以选择用Python调用Java。

Python是比较著名的胶水语言,他的特性就这么地显现出来了。本文就以Java使用Jieba分词构建一个jar包,供Python调用来做一个demo。

当然为了能够使用Python调用Jar当然少不了这个“胶水”,本文使用的是Jpype。Github地址:https://github.com/jpype-project/jpype。安装方式:pip install jpype1.

除此之外,因为需要运行jar包,当然我们运行环境中是需要有Java运行环境的。

Java

程序书写

为了从0开始,这里书写一个java程序如下:


package com.aiasbcyd;

import com.huaban.analysis.jieba.JiebaSegmenter;

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

public class jiebaSeg {
    private static JiebaSegmenter segmenter = new JiebaSegmenter();

    public static List<List<String>>  seg(List<String> sentences){
        List<List<String>> result = new ArrayList<>();
        for (String sentence : sentences) {
            List<String> strings = segmenter.sentenceProcess(sentence);
            result.add(strings);
        }
        return result;
    }

    public static void main(String[] args) {
        String test = "自然语言处理爱好者用NLP技术改变未来";
        List<String> inputStrings = new ArrayList<>();
        inputStrings.add(test);
        List<List<String>> lists = jiebaSeg.seg(inputStrings);
        System.out.println(lists);
    }
}


该Java程序是一个maven项目,引用了jieba对应的包,如下:

    <dependencies>
        <!-- https://mvnrepository.com/artifact/com.huaban/jieba-analysis -->
        <dependency>
            <groupId>com.huaban</groupId>
            <artifactId>jieba-analysis</artifactId>
            <version>1.0.2</version>
        </dependency>
    </dependencies>

打包

程序书写调试完之后就是将其打包,打的包就是python要调用的jar包了,所以此时还需要将其以来全部打进来,具体操作如不,
先做以下配置:
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
然后就是ok,apply了。然后就是打包了,

在这里插入图片描述
然后得到的jar包就供Python调用了。
在这里插入图片描述
有了jar包之后就是准备中使用Python进行调用了。

python

在安装jpype包后,使用如下代码就可以进行调用了。不过更多的操作需要查看jpype官方文档了。

import os
import jpype
from jpype.types import *


class SDKUse(object):

    def __init__(self, jar_path="./jar/jiebaSeg.jar"):
        if not os.path.exists(jar_path):
            raise FileNotFoundError
        self.jar_path = jar_path
        self._prepare_env()
        self.main_class = jpype.JClass("com.aiasbcyd.jiebaSeg")

    def _prepare_env(self):
        jpype.startJVM(classpath=[self.jar_path], convertStrings=False)

    def seg(self, content):
        j_list = jpype.java.util.ArrayList()
        j_list.append(JString(content))
        res = self.main_class.seg(j_list)
        print(res)


if __name__ == '__main__':
    sdk_use = SDKUse()
    sdk_use.seg("自然语言处理爱好者用NLP技术改变未来")

程序运行结果如下:
在这里插入图片描述

总结

跨语言调用还是挺有意思的,主要是有前人把包写好了。当然,由于Java是强类型语言,在python中需要根据接口需要的参数类型传入。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

智绘山河

你的鼓励可能解决你下一个问题

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值