1

我成功创建了一个包含文件的脚本,并且我成功地通过 jython 程序调用了这个脚本,

这是我的 Jython 过程:

import os    

cmd = "<%=odiRef.getSchemaName("script_path","D")%>/split_ncl.sh <%=snpRef.getSchemaName("data_in","D")%>/<%=odiRef.getOption("REP_FILE")%> <%=snpRef.getOption("FILENAME")%>"  

retcode = os.system(cmd)  
if retcode > 1 :      
    raise "Fatal ListError (%d)" % retcode, "Erreur de split"

这是我的脚本外壳 split_ncl.sh :

exec > Log/errors.log                                                                      
exec 2>&1

data_in=$1
fichier=$2

cd $data_in

#Purge des fichiers 

rm -f Split/INIT_ENC.dat
rm -f Split/INIT_ELP.dat


grep -P "^..........ENC" fichier ><!> Split/INIT_ENC.dat
grep -P "^..........ELP" $fichier >> Split/INIT_ELP.dat

一切正常。我添加exec > Log/errors.logexec 2>&1重定向我的脚本的所有错误到errors.log

当我在 UNIX 环境中执行脚本时,它运行良好,它可以记录错误,但是当我使用 ODI 并像我所做的那样通过 Jython 过程调用此脚本时,它无法检测到我的 shell 脚本的错误,例如,如果我把fichier而不是$fichier(缺少$),它不正确并且它无法检测到错误。我该如何解决这个问题!

4

1 回答 1

0

您应该使用 Python 的子进程库而不是 os。

os.system()发送命令,并返回成功消息。假设它是异步的,它不等待进程完成。它只会触发进程。

subprocess.call()发送命令,等待进程完成然后返回进程的返回码。

因此,如果您将代码更改为:

retcode = subprocess.call(cmd) 
if retcode > 1 :     
raise "Fatal ListError (%d)" % retcode, "Erreur de split"

还有一件事,如果您尝试捕获错误,请将您的条件语句更改为,retcode != 0因为错误的进程可以返回 0 以外的任何值。

更多信息:https ://docs.python.org/2/library/subprocess.html#replacing-os-system

于 2016-01-21T09:54:14.333 回答