![](/img/trans.png)
[英]Using the subprocess module in python to run a lua script with command line inputs
[英]using subprocess module in python to run isql command
我必须使用python运行isql命令。
目前我正在以这种方式
ps = subprocess.Popen("""./isql -I /app/sybase/interfaces_global -S %s -U %s -P %s -D %s -s "|" -w 99999 <<EOF
SET NOCOUNT ON
%s
go
EOF""" %(mdbserver,muserid,mpassword,mdatabase,User_Query),stdout=subprocess.PIPE,shell=True,cwd=sybase_path)
但是由于此文档,此方法取决于服务器的/ tmp目录,每次运行它时,它都会在/ tmp目录中创建一个tmp文件,而当/ tmp目录已满时,脚本将无法运行查询到数据库上。
我如何在shell=False
使用同一命令,以便摆脱这里的文档“”和临时文件的创建。
这行不通
ps = subprocess.Popen("./isql","-I","/app/sybase/interfaces_global","-S",mdbserver,"-U",muserid,"-P",mpassword,"-D",mdatabase,"-s","|","-w","99999","\nSET NOCOUNT ON\n",User_Query,"\ngo",stdout=subprocess.PIPE,shell=False,cwd=sybase_path)
您可以通过设置stdin=PIPE
并使用.communicate .communicate()
方法将输入作为字符串提供为@Hans来替换此处的文档, 然后建议 :
from subprocess import Popen, PIPE
from textwrap import dedent
isql = Popen(['./isql', '-I', '/app/sybase/...',
'-S', mdbserver,
'-U', muserid, ...,
'-w', '99999'], stdin=PIPE, stdout=PIPE, cwd=sybase_path)
output = isql.communicate(dedent("""\
SET NOCOUNT ON
{}
go
""".format(User_Query)))[0]
签出子流程communicate()
命令。 您可以使用它将isql命令发送到解释器。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.