繁体   English   中英

在python中使用子进程模块运行isql命令

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM