iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >java调用python的惨痛史(无法获
  • 536
分享到

java调用python的惨痛史(无法获

惨痛javapython 2023-01-30 23:01:11 536人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

环境:java,was,python2.6,红帽linux,oracle,Python用cx_Oracle        事情是这样的,有个需求,需要对数据库进行处理,简单说就是把数据取出来,用python使用外部传参做一个处理,再写回到

环境:java,was,python2.6,红帽linuxoraclePython用cx_Oracle
        事情是这样的,有个需求,需要对数据库进行处理,简单说就是把数据取出来,用python使用外部传参做一个处理,再写回到数据库。如果使用java直接搞的话需要绕很大一个圈,比较麻烦,用python的话就很简单了,于是就有了下面的故事,希望和我遇到同样问题的同学能对你们有一些帮助,少绕一些圈子,java和python功能开发都很顺利,于是到了java调用python环节


大概把需要用到的功能写两个脚本,一个是用于连接数据库的,一个是用来实现功能的,方便后面说明
dbconn.py 这个用来连接数据库

#!/usr/bin/python
# coding: UTF-8

import cx_Oracle

def ora_conn():
  user_name = 'user'
  passwd = 'pass'
  host = 'localhost/orcl'
  conn = cx_Oracle()
  return conn

case.py 这个用来加工数据

'''
接收传入参数
使用传入参数作为where条件到oracle中进行查找
对数据进行处理
写回到oracle
'''
#!/usr/bin/python
# coding: UTF-8

import os
import sys

#尝试获取环境变量my_home
my_home = os.getenv('my_home')
if not my_home:
  my_home = '/home/user_name'

#cx_Oracle脚本是放在pypk目录里的,因此需要增加这个地方
sys.path.append('%s/pypk' %my_home) 

import dbconn

#接收参数,为了防止后面因为手误将此变量变更这里用global声明下全局,可有可无
global out_into
out_into = sys.argv[1]

#获取数据库数据
def get_data():
  print 'get data'
  conn = dbconn.ora_conn()
  conn_cur = conn.cursor()
  sql = 'select col1,col2 from tablename where col1 = %r' %out_into
  data_values = conn_cur.execute(sql)
  result = list(data_values)
  conn_cur.close()
  conn.close()
  return result

#处理,为了方便,假设就是在col1前面加a和col2前面加b,然后拼在一起用;分隔
def manage_data(values):
  print 'manage data'
  col1 = 'a' + str(values[0])
  col2 = 'b' + str(values[1])
  col_return = col1 + ';' + col2
  return col_return

#写入数据库d
def into_data(into_values):
  print 'insert into data'
  conn = dbconn.ora_conn()
  conn_cur = conn.cursor()
  sql = 'insert into result_table(col) values(%r)' %into_values
  conn_cur.execute(sql)
  conn.commit()
  conn_cur.close()
  conn.close()

def main():
  print 'run start'
  datas = get_data()
  for line in datas:
    ok_values = manage_data(line)
    into_data(ok_values)

if __name__ == '__main__':
  main()
  exit()

 

因为不知道java调用效果怎样,先写了个简单的python脚本用java调用测试了下

test.py 这个只是用来测试功能,所以只有一行代码

print 'hello'

测试成功,这里因为这边没有环境,就不截图了,大家凑合看吧。又加入两行,测试了一下传参

test.py

print 'hello'
a = sys.argv[1]
print a

 

一样成功了,信心满满的上正式脚本来测试,正常打印了脚本中的内容

run start
get data
manage data
insert into data

去数据库里面查,结果目标表result_table没有数据。我擦,这什么鬼,没报错也没有处理,完全没有头绪,尝试加上try看看有没有什么帮助。于是case.py的main函数就变成了下面这样

def main():
  print 'run start'
  try:
    datas = get_data()
    for line in datas:
      ok_values = manage_data(line)
      into_data(ok_values)
  except Exception, e:
    print e

 

       这次果然有结果了,cx_Oracle连接失败,缺少libclntsh.so.11.1,这里着重说明下,网上都是win调用cx_Oracle的,需要拷贝什么dll,这个在linux中是没用的,而且就算是win也不是像上面说的那样把一堆dll拷贝到脚本当前目录里面,这样只是治标不治本。
正确的方法是加三个环境变量

export ORACLE_HOME=oracle_install_path #第一个当然是ORACLE_HOME
export PATH=$PATH:$ORACLE_HOME/bin #第二个是bin
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib #第三个是lib

我不想留坑,建议这三个变量加到~/.bashrc里面,不过这个并没有解决根本问题,后面会说明,请各位继续往下看


        加入环境变量以后又执行了下,报错connect to Oracle Database,尼玛犬加上了啊,于是在本地linux服务器执行了下,结果。。。。。。正常执行,完全问题,这次真是见鬼了啊。某楠说的好,真相只有一个,特么就不信了,我倒要看看是出什么问题了,根据以往经验,环境变量加失败的话可能是使用用户和加环境变量的用户不一致,于是在case.py里面加上一段

import getpass
now_user = getpass.getuser() #用来获取当前操作用户
print now_user

结果是root,对啊,是root啊,而且我也是SB了,.bashrc这个不是应该全局的么,就是全部用户通用的环境变量啊。算了,死马当活马医,倒要看看环境变量里都是什么玩意,在case.py里面再加一行

os.system('env') #调用linux的外部命令,查看全部环境变量

 

        然后,意外出现了,打印出来的环境变量里面根本就没有加入的三个环境变量,而且大部分都不是linux里面的环境变量,好多都是was用的,难道是was有自己的环境变量么,问了下同事,果然坑啊,真的有自己的环境变量配置。这下问题找到了,那么解决办法就是把这三个加到was自有的环境变量里面就好了嘛,于是。。。。。。在was里加入了ORACLE_HOME、PATH、LD_LIBRARY_PATH这三个环境变量。
        重新测试下,尼玛刚才加入的居然不在里面,这就尴尬了,怎么办。。。怎么办。。。在分针从12绕到11的时候,终于,办法有了,把环境变量作为外部命令加进去不就行了,继续在case.py中加入三行

os.system(export ORACLE_HOME=oracle_install_path)
os.system(export PATH=$PATH:$ORACLE_HOME/bin)
os.system(export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib)

 

        这时候我都快成福尔摩斯了,感觉已经超越某楠了有木有,但是事实仍然给了我当头一棒,失败了,打印出来的环境变量里这三个依然不存在的,原因是这样加入的环境变量不会直接有效的,需要注销才可以生效,简直崩溃了,然后分针又默默的从12走到了11。突然灵感一现,如果用python自有的加环境变量的方法能不能绕过注销这个步骤呢,说弄就弄,于是将case.py中的

os.system(export ORACLE_HOME=oracle_install_path)
os.system(export PATH=$PATH:$ORACLE_HOME/bin)
os.system(export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/lib)

替换成下面的

oracle_home_env = [['ORACLE_HOME','oracle_install_path'],['PATH','$PATH:$ORACLE_HOME/bin'],['LD_LIBRARY_PATH','$LD_LIBRARY_PATH:$ORACLE_HOME/lib']]
for env_line in oracle_home_env:
  os.environ[env_line[0]] = env_line[1]

好吧,我承认,这个办法不是我想出来的,能相出这种加环境变量方法的人真是大神啊


        继续我们的故事,然后,奇迹出现了,这三个环境变量终于在打印的结果中出现了,但是依然报错连接不上数据库,不过这就好办了,既然这个环境变量指向的linux,那只要用linux的方法调用脚本就好了嘛。说弄就弄,新加了一个脚本,用来调用case.py,只有几行

call_script.py 用来使用外部命令调用case.py

#!/usr/bin/python
# coding: UTF-8

import os

out_into = sys.argv[1]

my_home = os.getenv('my_home')
if not my_home:
  my_home = '/home/user_name'

os.system('python %s/case.py %s' %(my_home,out_into))

到这里故事就结束了,不过就像大部分剧本一样,总要有彩蛋嘛哈哈


        以为这样就结束了么?当然不是,有没有看到my_home,这个也是一个环境变量!这里没有报错的原因是因为在下面加入了一个if,如果没有获取到的话默认/home/user_name,但是路径换了呢?这一路升级的,感觉小棍子都能升级到金箍棒了,这点小事还搞不定么,好了,不说了,我要去吃点什么庆祝了。


春节了,一年了,终于等到这一天了,能看到这个文也算是缘分,在这里就祝大家在新的一年里 多多赚钱、少一些坑、身体健健康康、立的flag都能实现!

--结束END--

本文标题: java调用python的惨痛史(无法获

本文链接: https://www.lsjlt.com/news/181074.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • java调用python的惨痛史(无法获
    环境:java,was,python2.6,红帽linux,oracle,python用cx_Oracle        事情是这样的,有个需求,需要对数据库进行处理,简单说就是把数据取出来,用python使用外部传参做一个处理,再写回到...
    99+
    2023-01-30
    惨痛 java python
  • Java之——调用python方法
    转载请注明出处:http://blog.csdn.net/l1028386804/article/details/50915556 今天,给大家介绍下如何在java中调用python方法。下面我们进入正题 1.在java类中直接执行pyt...
    99+
    2023-01-31
    方法 Java python
  • java调用python方法总结
    http://download.csdn.net/detail/xingjiarong/9429266 下载jython包,把其中的jython.jar添加到工程目录 一、在java类中直接执行python语句 import or...
    99+
    2023-01-31
    方法 java python
  • python中无法调用numpy的原因有哪些
    1. 未正确安装NumPy库:如果没有正确安装NumPy库,就无法在Python中调用它的功能。2. 忘记导入NumPy模块:在Py...
    99+
    2023-09-08
    python numpy
  • Python无法用requests获取网页源码的解决方法
    最近在抓取http://skell.sketchengine.eu网页时,发现用requests无法获得网页的全部内容,所以我就用selenium先模拟浏览器打开网页,再获取网页的源...
    99+
    2024-04-02
  • python调用接口获取数据的方法是什么
    在Python中调用接口获取数据的方法有几种:1. 使用内置的`urllib`或`urllib2`模块进行接口调用。这些模块提供了H...
    99+
    2023-08-29
    python
  • Java调用Python程序方法总结
    如何使用Java调用Python程序 本文为大家介绍如何java调用python方法,供大家参考。 实际工程项目中可能会用到Java和python两种语言结合进行,这样就会涉及到一个问题,就是怎么用Java程序来调用已经写好的py...
    99+
    2023-01-31
    程序 方法 Java
  • java中方法的调用
    1.静态方法调用静态方法: 用静态方法时通过(类名.方法名)的方法进行调用,当调用方法和被调用的方法在同一类中时,类名可省略,直接通过方法名进行调用; 同时也可以通过对象进行调用,但较为繁琐,一般不使...
    99+
    2023-09-22
    java
  • Java调用Python程序方法总结(最
    如何使用Java调用Python程序本文为大家介绍如何java调用python方法,供大家参考。 实际工程项目中可能会用到Java和python两种语言结合进行,这样就会涉及到一个问题,就是怎么用Java程序来调用已经写好的pytho...
    99+
    2023-01-31
    程序 方法 Java
  • Python调用MongoDB的方法
    这篇文章将为大家详细讲解有关Python调用MongoDB的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。  使用pymongo对MongoDB进行的各种操作,下载相...
    99+
    2024-04-02
  • python递归调用的用法
    这篇文章主要讲解了“python递归调用的用法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“python递归调用的用法”吧!题目:    一个5位数,...
    99+
    2023-06-04
  • php无法调用linux命令的解决方法
    这篇文章给大家分享的是有关php无法调用linux命令的解决方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。php无法调用linux命令的方法:1、关闭selinux;2、在httpd.conf配置文件中添加a...
    99+
    2023-06-15
  • 无法调用嵌入的 css/js 文件
    怎么入门Golang编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面编程网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《无法调用嵌入的 css/js 文件...
    99+
    2024-04-05
  • Python里调用redis的方法
    Python 2.7里不是自带redis的,那么在调用redis的时候自然也会报错,比如:遇到这种情况怎么办?第一种方法:pip install redis第二种方法:easy_install redis第三种方法:去登录https://g...
    99+
    2023-01-31
    方法 Python redis
  • JavaScript如何调用Java的方法
    这篇“JavaScript如何调用Java的方法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这...
    99+
    2024-04-02
  • 调试设置中的python路径无效的解决方法
    这篇文章给大家分享的是有关调试设置中的python路径无效的解决方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。解决方法:首先点击页面底部的“设置”图标按钮,在弹出的窗口里点击“扩展”-“python”;然后在...
    99+
    2023-06-15
  • Java中调用Python的实现示例
    目录Java core使用ProcessBuilder使用Java脚本引擎总结Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求...
    99+
    2023-05-18
    java调用python脚本 java调用python
  • python--类属性的调用方法
    测试时候类的调用是经常会用到的。简单看下类的调用使用的方法吧。 来看例子:目录结构: 我们现在要在do_class.py这个文件里调用class_learn.py里的类 代码(do_class.py): #!/usr/bin/env pyt...
    99+
    2023-01-31
    方法 类属 python
  • python调用matlab的方法详解
    目录1.python版本与matlab版本的对应关系2.import matlab.engine的问题3.代码报错:please use torch.load with map_lo...
    99+
    2024-04-02
  • java ffmpeg调用的方法是什么
    Java中调用FFmpeg的方法是使用Java的外部命令执行功能来执行FFmpeg命令。 可以使用Java的ProcessBuild...
    99+
    2023-10-23
    java ffmpeg
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作