#-*-coding:utf-8 -*-
import numpy as np
from selenium import webdriver
def main():
url = 'https://www.tianyancha.com/login'
driver = webdriver.Chrome()
driver.get(url)
if __name__ == '__main__':
a = np.ones(3)
print(a)
print('java 调用有第三方库的python脚本成功')
main()
package Jpython;
import java.io.BufferedReader;
import java.io.InputStreamReader;
public class test20190712 {
public static void main(String[] args){
try{
System.out.println("start");
String[] arg1 = new String[]{"python","F:\\jupyter\\java\\server\\DataEye\\java_base\\src\\main\\java\\Jpython\\test20190712.py"};
Process pr = Runtime.getRuntime().exec(arg1);
// 二进制流
BufferedReader in = new BufferedReader(new InputStreamReader(
pr.getInputStream(),"gb2312"
));
String line;
while ((line=in.readLine())!=null){
System.out.println(line);
}
in.close();
pr.waitFor();
System.out.println("end");
}catch (Exception e){
e.printStackTrace();
}
}
}
乱码解决
方法1(java中设置编码)
这里调用python使用的是Process,然后把输入流的字符编码设置成GB2312即可。
BufferedReader in =
new BufferedReader(new InputStreamReader(process.getInputStream(),"gb2312");
切记:不可读取完字节流后,在重新getByte编码,本人测试过,这样的方法也是乱码的,如下代码是不可行!!!
BufferedReader in = new BufferedReader(new InputStreamReader(process.getInputStream()));//,"gb2312"
String line;
while ((line = in.readLine()) != null) {
line = new String(line.getBytes("GB2312"),"utf-8");
System.out.println(line);
}
方法2(python中设置编码)
你可能未必使用Process调用,所以可能和我调用方式不同,所以也可以在python中设置编码格式,如下代码:
import sys
import io
sys.stdout = io.TextIOWrapper(sys.stdout.buffer, encoding='utf-8')