maven-3-java调用python程序

news2024/11/15 15:59:22

【Java】使用Java调用Python的四种方法
fastjson的使用——JSON字符串、JSON对象、Java对象的互转
使用idea给Java程序打jar包(超简单 超详细)

1 环境准备

(1)新建Maven类型的项目,D:\processPython。
右键src/main/java,创建java类。

(2)在使用Java调用python之前,需要导入依赖环境。
如,在maven项目中,需要导入如下依赖:
目前只有2.7.X版本有相关依赖包。

<dependencies>
        <dependency>
            <groupId>org.python</groupId>
            <artifactId>jython-standalone</artifactId>
            <!--python版本是2.x还是3.x在这里指定-->
            <version>2.7.1</version>
        </dependency>
    </dependencies>

2 调用

2.1 在java类中直接执行python语句

创建Java类JavaRunPython。

import org.python.util.PythonInterpreter;
public class JavaRunPython {
    public static void main(String[] args) {
        //首先调用python的解释器
        PythonInterpreter interpreter = new PythonInterpreter();
        //选择执行的的Python语句
        interpreter.exec("import sys; ");
        interpreter.exec("a='hello world123'; ");
        interpreter.exec("print(sys.version,a);");
    }
}
输出如下:
('2.7.1 (default:0df7adb1b397, Jun 30 2017, 19:02:43) 
[Java HotSpot(TM) 64-Bit Server VM (Oracle Corporation)]',
'hello world123')

在正常的情况下,Java工程师只需要调用python开发工程师写的脚本就行了,不会再在代码中加入python语句了。因为在Java语言中添加入其他语言,使Java的可读性下降、执行意义也不是很大。

2.2 在java中直接调用python脚本

这种方式是有些Java程序员使用调用。
(1)首先将准备好的脚本,如plus.py。

import sys
a = 100
b = 200
print(sys.version,a+b)

(2)创建java类JavaPythonFile

import org.python.util.PythonInterpreter;
public class JavaPythonFile {
    public static void main(String[] args) {
        PythonInterpreter interpreter = new PythonInterpreter();
        //我在这里使用绝对路径
        interpreter.execfile("D:\\processPython\\src\\main\\java\\plus.py");
    }
}
输出如下:
('2.7.1 (default:0df7adb1b397, Jun 30 2017, 19:02:43) 
[Java HotSpot(TM) 64-Bit Server VM (Oracle Corporation)]', 300)

2.3 用Runtime.getRuntime()执行python脚本

这种办法可以让进程与程序交互,可以看到出现的问题,便于解决。
(1)首先将准备好的脚本,如plus.py。

a = 100
b = 200
print(a+b)

(2)创建java类RuntimeFunction

2.3.1 方式一系统默认python

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class RuntimeFunction {
    public static void main(String[] args) {
        Process proc;
        try {
            proc = Runtime.getRuntime().exec("python D:\\processPython\\src\\main\\java\\plus.py");
            BufferedReader in = new BufferedReader(new InputStreamReader(proc.getInputStream()));
            String line = null;
            while ((line = in.readLine()) != null) {
                System.out.println(line);
            }
            in.close();
            proc.waitFor();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}
输出如下
3.7.4 (default, Aug  9 2019, 18:34:13) [MSC v.1915 64 bit (AMD64)] 300

查看系统的python版本为3.7.4。
在这里插入图片描述

2.3.2 方式二指定python

String[] args1=new String[]{"/home/huan/anaconda2/bin/python","/home/huan/myfile/helloword.py"};
Process pr=Runtime.getRuntime().exec(args1);

附加:String数组里的那一行很重要。
首先一定要设置好你所使用的python的位置,切记不要直接使用python,因为系统会默认使用自带的python,所以一定要设置好你所使用的python的位置,否则可能会出现意想不到的问题(比如说我使用的是anaconda中的python,而ubuntu系统会默认调用自带的python,而我自带的python中并没有numpy库,所以会造成相应的代码不会执行的问题,所以设置好python的位置是很重要的)。还有就是要设置好py文件的位置,使用绝对路径。还有就是可以看出,此方法可以满足我们python代码中调用第三方库的情况,简单实用。

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class RuntimeFunction {
    public static void main(String[] args) {
        Process proc;
        try {
            String[] args1=new String[]{"D:\\Anaconda3\\envs\\python38\\python","D:\\processPython\\src\\main\\java\\plus.py"};
            proc = Runtime.getRuntime().exec(args1);
            BufferedReader in = new BufferedReader(new InputStreamReader(proc.getInputStream()));
            String line = null;
            while ((line = in.readLine()) != null) {
                System.out.println(line);
            }
            in.close();
            proc.waitFor();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

首先,为什么要创建Process proc。ProcessBuilder.start()和Runtime.exec两个方法会生成一个本地的进程,然后返回一个Processs子类的实例。通过这个实例可以控制进程以及获得关于进程的信息。这个Process类为进程提供可用于执行来自的输入的方法,然后执行输出到这个进程中,等待完成后,检查进程退出时的状态,然后停止这个进程。——换句话说,这个实例就是监视整个进程的。

通过Process的getInputStream(),getOutputStream()和getErrorStream()方法可以得到输入输出流,然后通过InputStream可以得到程序对控制台的输出信息,通过OutputStream可以给程序输入指令,这样就达到了程序的交换功能。

3 java处理json

如果使用的是maven,需要在pom.xml文件中加入依赖:

<dependency>
	<groupId>com.alibaba</groupId>
	<artifactId>fastjson</artifactId>
	<version>1.2.78</version>
</dependency>

3.1 json字符串-简单对象

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
public class JavaJsonProcess {
    public static void main(String[] args) {
        //json字符串-简单对象
        String jsonStr = "{\"studentName\":\"张三\",\"studentAge\":18}";
        //简单对象
        JSONObject jsonObj = JSON.parseObject(jsonStr);
        System.out.println(jsonStr);
        System.out.println(jsonObj);
    }
}

3.2 json字符串-数组类型

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
public class JavaJsonProcess {
    public static void main(String[] args) {
        //json字符串-数组类型
        String jsonArrStr = "[{\"studentName\":\"张三\",\"studentAge\":18},{\"studentName\":\"李四\",\"studentAge\":17}]";
        //数组类型
        JSONArray jsonArray = JSON.parseArray(jsonArrStr);
        //遍历JSONArray方法1
        for(int i = 0; i < jsonArray.size(); i++){
            JSONObject jsonObj = jsonArray.getJSONObject(i);
            System.out.println(jsonObj);
        }

        //遍历JSONArray方法2
        for(Object obj : jsonArray){
            JSONObject jsonObject = (JSONObject) obj;
            System.out.println(jsonObject);
        }
	}
}

3.3 json字符串-复杂对象

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
public class JavaJsonProcess {
    public static void main(String[] args) {
        //json字符串-复杂对象
        String complexJsonStr= "{\"teacherName\":\"李寻欢\",\"teacherAge\":30,\"course\":{\"courseName\":\"武术\",\"code\":110},\"students\":[{\"studentName\":\"张三\",\"studentAge\":18},{\"studentName\":\"李四\",\"studentAge\":19}]}";
        //复杂对象
        JSONObject jsonObj = JSON.parseObject(complexJsonStr);
        //取出复杂对象中各项内容
        String teacherName = jsonObj.getString("teacherName");
        Integer teacherAge = jsonObj.getInteger("teacherAge");
        JSONObject course = jsonObj.getJSONObject("course");
        JSONArray students = jsonObj.getJSONArray("students");
        System.out.println(teacherName);
        System.out.println(teacherAge);
        System.out.println(course);
        System.out.println(students);
    }
}
输出如下:
李寻欢
30
{"courseName":"武术","code":110}
[{"studentAge":18,"studentName":"张三"},{"studentAge":19,"studentName":"李四"}]

4 方式一:传递json参数

用sys.argv接收参数。

4.1 依赖引用pom.xml

如果使用的是maven,需要在pom.xml文件中加入依赖:

<dependency>
	<groupId>com.alibaba</groupId>
	<artifactId>fastjson</artifactId>
	<version>1.2.78</version>
</dependency>

4.2 配置文件pythonuse.properties

在这里插入图片描述

#python.path = python
python.path = D:\\Anaconda3\\envs\\python38\\python33
python.package = C:\\Users\\user\\Desktop\\aa_main.py

4.3 代码RuntimeFunction.java

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.Properties;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
public class RuntimeFunction {
    public static void main(String[] args) {
        Process proc;
        try {
            //通过java反射机制获取配置文件
            InputStream is = RuntimeFunction.class.getClassLoader().getResourceAsStream("pythonuse.properties");
            Properties pro = new Properties();
            try {
                pro.load(is);
            } catch (IOException e1) {
                e1.printStackTrace();
            }
            String pythonpath = pro.getProperty("python.path");
            String pythonpackage = pro.getProperty("python.package");

            //json字符串-简单对象
            String jsonStr = "{\"name\":\"张三\",\"time\":\"2022-12-10 16:16:45.256\",\"age\":18}";
            System.out.println(jsonStr);
            //简单对象
            JSONObject jsonObj = JSON.parseObject(jsonStr);
            //简单对象转换为字符串
            String re_str = jsonObj.toJSONString();
            System.out.println(re_str);
            //将“替换成\"
            re_str = re_str.replaceAll("\"","\\\\\"");
            System.out.println(re_str);

            //String[] args1=new String[]{"D:\\Anaconda3\\envs\\python38\\python","C:\\Users\\user\\Desktop\\aa_main.py",re_str};
            String[] args1=new String[]{pythonpath,pythonpackage,re_str};
            //System.out.println(args1);
            proc = Runtime.getRuntime().exec(args1);
            BufferedReader in = new BufferedReader(new InputStreamReader(proc.getInputStream()));
            String line = null;
            while ((line = in.readLine()) != null) {
                System.out.println(line);
                JSONObject jsonObj1 = JSON.parseObject(line);
                System.out.println(jsonObj1);
            }
            in.close();
            proc.waitFor();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}


4.4 代码aa_main.py

# -*- coding: UTF-8 -*-
import sys
import json
import sys
if __name__ == "__main__":
    # 1 当作命令行参数,容易出现时间戳中的空格,被拆分成了多个参数
    receive_msg = " ".join(sys.argv[1:]) # 用空格把分隔的参数合并起来
    # 2 解析
    receive_dict = json.loads(receive_msg)
    # print(receive_dict["name"],receive_dict["age"],receive_dict["time"])
    out_dict = {
        "接收到":receive_dict
    }
    # 3 序列化
    msg = json.dumps(out_dict)
    msg = msg.replace('"','\"')
    print(msg)

4.5 打包和运行

(1)打包后会自动将配置文件加载到与类文件同一级目录
在这里插入图片描述
(2)执行命令

java -cp processPython.jar  RuntimeFunction main

在这里插入图片描述

5 方式二:传递json参数

将json参数传递到控制台的命令行。

5.1 代码RuntimeFunction.java

import java.io.*;
import java.util.Properties;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
public class RuntimeFunction {
    public static void main(String[] args) {
        Process proc;
        try {
            //通过java反射机制获取配置文件
            InputStream is = RuntimeFunction.class.getClassLoader().getResourceAsStream("pythonuse.properties");
            Properties pro = new Properties();
            try {
                pro.load(is);
            } catch (IOException e1) {
                e1.printStackTrace();
            }
            String pythonpath = pro.getProperty("python.path");
            String pythonpackage = pro.getProperty("python.package");

            //json字符串-简单对象
            String jsonStr = "{\"name\":\"张三\",\"time\":\"2022-12-10 16:16:45.256\",\"age\":18}";
            System.out.println(jsonStr);
            //简单对象
            JSONObject jsonObj = JSON.parseObject(jsonStr);
            //简单对象转换为字符串
            String re_str = jsonObj.toJSONString();
            System.out.println(re_str);

            //String[] args1=new String[]{"D:\\Anaconda3\\envs\\python38\\python","C:\\Users\\user\\Desktop\\aa_main.py",re_str};
            String[] args1=new String[]{pythonpath,pythonpackage};
            proc = Runtime.getRuntime().exec(args1);
            // 向控制台的命令行中写入参数
            PrintStream ps = new PrintStream(proc.getOutputStream());
            ps.print(re_str);
            ps.flush();
            ps.close();

            // 从控制台的命令行读取返回的参数
            BufferedReader in = new BufferedReader(new InputStreamReader(proc.getInputStream()));
            String line = null;
            while ((line = in.readLine()) != null) {
                System.out.println(line);
                JSONObject jsonObj1 = JSON.parseObject(line);
                System.out.println(jsonObj1);
            }
            in.close();
            proc.waitFor();
        } catch (IOException e) {
            e.printStackTrace();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

5.2 代码aa_main.py

# -*- coding: UTF-8 -*-
import sys
import json
import sys
if __name__ == "__main__":
    # 方式二:直接从命令行
    x = sys.stdin
    for line in x:
        # 2 解析
        receive_dict = json.loads(line)
        # print(receive_dict["name"],receive_dict["age"],receive_dict["time"])
        out_dict = {
            "接收到":receive_dict
        }
        # 3 序列化
        msg = json.dumps(out_dict,ensure_ascii=False)
        print(msg)
        break

6 打包运行

6.1 打包

1.file ---> project structure --->Artifacts--->+ --->JAR--->
From  modules with dependencies...---> Main class(选择启动类)--->
OK--->apply --->OK 
2.build ---> build Artifacts--->xxx.jar ---> build

6.2 运行

直接通过命令指定运行,运行时指定的main方法:

java -cp huobi-client.jar com.huobi.start.LoadPrice main

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/176250.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于深度学习的文本分类6大算法-原理、结构、论文、源码打包分享

导读&#xff1a;文本分类是NLP领域一项基础工作&#xff0c;在工业界拥有大量且丰富的应用场景。传统的文本分类需要依赖很多词法、句法相关的human-extracted feature&#xff0c;自2012年深度学习技术快速发展之后&#xff0c;尤其是循环神经网络RNN、卷积神经网络CNN在NLP领…

【Leetcode面试常见题目题解】8. 合并两个有序链表

前言 本文是LC第21题&#xff1a;合并两个有序链表 题目描述 将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 提示&#xff1a; 两个链表的节点数目范围是 [0, 50] -100 < Node.val < 100 l1 和 l2 均按 非递减顺…

产品设计-基础控件-信息反馈控件

产品设计-基础控件-信息反馈控件1.1 吐司提示1.2 对话框1.3 气泡卡片1.4 动作面板和弹出层1.4.1 动作面板1.4.2 弹出层1.5 进度条和加载状态1.5.1进度条1.5.2 加载状态1.1 吐司提示 用户输入信息后&#xff0c;一个好的产品设计会给予用户明确的信息反馈&#xff0c;例如&…

五、pyhon-地图可视化篇(黑马程序猿-python学习记录)

黑马程序猿的python学习视频&#xff1a;https://www.bilibili.com/video/BV1qW4y1a7fU/ 目录 1. 基础地图 2. 设置分段 1. 基础地图 from pyecharts.charts import Map # 准备地图对象 map Map() # 准备数据 data[ ("北京",99), ("上海",199), ("…

【2023.01.23】定时执行专家 V6.6 兔年春节版 - 更新日志

目录 ◆ 最新版下载链接 ◆ 软件更新日志 – TimingExecutor Full Change Log ▼ 2023-01-23 V6.6 ▼ 2023-01-20 V6.5 ▼ 2022-12-25 V6.4 ▼ 2022-11-15 V6.3 ▼ 2022-10-01 V6.2 ▼ 2022-07-30 V6.1&#xff08;Build 769.30072022&#xff09; ▼ 2022-0…

[前端笔记——CSS] 10.层叠与继承+选择器

[前端笔记——CSS] 10.层叠与继承选择器1.层叠与继承1.1 冲突规则1.2 继承1.3 层叠1.4 CSS位置的影响2.选择器2.1 选择器是什么&#xff1f;2.2 选择器列表2.3 选择器的种类类型、类和 ID 选择器标签属性选择器伪类与伪元素运算符选择器参考表1.层叠与继承 1.1 冲突规则 CSS …

动态规划(基础)

目录 一、算法思想 二、解题步骤 三、神奇的兔子序列 &#xff08;一&#xff09;问题 &#xff08;二&#xff09;递归公式 &#xff08;三&#xff09;以求解F(6)为例 &#xff08;四&#xff09;代码 四、01背包问题 &#xff08;一&#xff09;算法思想 &…

深入跨域问题(4) - 利用代理解决跨域

在上面的文章中&#xff0c;我们依此了解到&#xff0c;CORS &#xff0c;JSONP 两种方式实现跨域请求。 这两种方法&#xff0c;都需要 前后端进行配合 才能够正确地处理跨域问题。 今天介绍一种方法&#xff0c;不需要前后端配合&#xff0c;前端可独立完成。 众所周知&…

Java的基本语法格式

在编写JavaJavaJava代码过程中&#xff0c;必须先声明一个类&#xff0c;类使用class字眼定义&#xff0c;在class前面可以有一些修饰符&#xff1a; class的修饰符有&#xff1a; public&#xff0c;final(默认是default&#xff0c;只允许在同一包中进行访问) public&#xf…

C++STL-priority_queue的实现

大家好&#xff01;这篇文章&#xff0c;主要讲解一下这个优先级队列&#xff0c;还包含了仿函数等等的知识。希望大家能够一起加油&#xff01;&#xff01;&#xff01; 文章目录1. priority_queue的实现1.1 push函数1.2 pop函数1.3 top函数和empty函数2. 仿函数2.1 仿函数的…

【C进阶】模拟实现atoi函数

⭐博客主页&#xff1a;️CS semi主页 ⭐欢迎关注&#xff1a;点赞收藏留言 ⭐系列专栏&#xff1a;C语言进阶 ⭐代码仓库&#xff1a;C Advanced 家人们更新不易&#xff0c;你们的点赞和关注对我而言十分重要&#xff0c;友友们麻烦多多点赞&#xff0b;关注&#xff0c;你们…

day21-多线程

1.实现多线程 1.1简单了解多线程【理解】 是指从软件或者硬件上实现多个线程并发执行的技术。 具有多线程能力的计算机因有硬件支持而能够在同一时间执行多个线程&#xff0c;提升性能。 1.2并发和并行【理解】 并行&#xff1a;在同一时刻&#xff0c;有多个指令在多个CP…

【数据结构】双链表实现

双链表实现双链表LinkedList的使用ArrayList 和 LinkedList的区别双链表 双链表的结点其实就是在单链表结点的基础上多了一个存储前一个节点地址的域&#xff0c;例如&#xff1a; 接下来就实现双链表的各种操作&#xff0c;首先定义好双链表的结构&#xff1a; public class…

【经典算法】双指针(尺取法):爱,是双向奔赴,还是你追我赶?

&#x1f451;专栏内容&#xff1a;算法学习随笔⛪个人主页&#xff1a;子夜的星的主页&#x1f495;座右铭&#xff1a;日拱一卒&#xff0c;功不唐捐 目录一、前言二、左右指针&#xff08;双向奔赴&#xff09;1、定义2、回文检查三、快慢指针&#xff08;你追我赶&#xff…

将字符串代码编译为字节代码对象 compile()

【小白从小学Python、C、Java】【计算机等级考试500强双证书】【Python-数据分析】将字符串代码编译为字节代码对象compile()[太阳]选择题关于以下python代码表述错误的一项是?sx1y2print("xy",xy)print("【显示】s&#xff1a;")print(s)print("【执…

fpga实操训练(一个典型的fpga系统)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing @163.com】 对于刚学习fpga的同学来说,很多人可能一开始并不了解,一个典型的fpga系统应该是什么样子的。今天正好来熟悉一下。此外,我们也可以通过这个系统,从另外一个角度学习下,为什么要…

【蓝桥杯】简单数论——快速幂矩阵快速幂

1、快速幂 1.1运算模 定义&#xff1a;模运算为a除以m的余数&#xff0c;记为a mod m&#xff0c;有a mod m a % m。 模运算是大数运算中的常用操作&#xff1a;如果一个数太大&#xff0c;无法直接输出&#xff0c;或者不需要直接输出&#xff0c;可以把它取模后&#xff…

2.4总线操作和定时

文章目录一、引子二、介绍1.总线周期2.总线定时规范三、同步定时方式1.过程2.特点3.优缺点①优点②缺点四、异步定时方式1.介绍2.三种方式&#xff08;1&#xff09;不互锁方式&#xff08;2&#xff09;半互锁方式&#xff08;3&#xff09;全互锁方式3.优缺点①优点②缺点五、…

Allegro如何统计包含过孔长度的网络长度操作指导

Allegro如何统计包含过孔长度的网络长度操作指导 当需要统计网络长度的时候,可以通过element选择nets看到网络的长度,但是当网络换层了,并且需要统计到过孔的长度,类似下图 Allegro可以快速的统计网络的长度,并且包含过孔的长度 具体操作如下 选择Setup选择Constraint –…

设计模式 - 六大设计原则之SRP(单一职责)

文章目录概述CaseBad ImplBetter Impl1. 定义接口2. 职责分离-多种实现类3. 单元测试小结概述 单一职责原则&#xff08;Single Responsibility Principle&#xff0c; SRP&#xff09;又称单一功能原则&#xff0c;是面向对象的五个基本原则&#xff08;SOLID&#xff09;之一…