gpt4 book ai didi

Python,引号中的引号

转载 作者:行者123 更新时间:2023-11-28 21:28:08 24 4
gpt4 key购买 nike

我正在尝试构建一个 nagios 脚本,但在双引号内出现单引号问题。

我正在尝试传递以下内容:

select (select count(*) from v$session)/(select value from v$parameter where name = 'processes')*100 Percent from dual"

选择必须像上面一样被引用。

我尝试以各种方式将其传递到字符串中:

line=select (select count(*) from v$session)/(select value from v$parameter where name = 'processes')*100 Percent from dual"

比创建这样的命令:

process= '"' + line + '"'

p = subprocess.Popen( line.split())

不幸的是,line.split 没有进行正确的引号解析。

“select”必须用引号引起来,'processes' 必须用单引号引起来。

有什么建议吗?

更新:

显然问题出在“拆分”过程中。 sql 语句必须原封不动地传递,并作为单个语句引用。但是,我已经传递了相当多的复杂参数,并且 line.split 对此起作用,直到我遇到这个问题。

所以更好的问题是我如何格式化子进程以发送整个字符串以及一个长列表(大约 5 个字符串参数)?

更新:

如果这对某人有帮助。显然,对于 Popen,您必须划分参数和输入。例如,您不能发送 "--test blah";它必须是 "--test", "blah"。这意味着要发送一个字符串,您必须将其拆分。

但是,如果需要整个字符串,您必须对其进行编辑并将其附加到列表中。

例如

a = "--test blah --something other"
b = a.split()

这将生成一个列表,Popen 将很好地处理它(使用 subprocess.Popen(b))。

但是,如果您还需要像这样发送整个字符串:

sql = "select count(*) from v$session"

你不能像在 a + sql 中那样将它添加到“a string”。你需要做这样的事情:

b.append(sql)

这将添加整个字符串,然后 Popen 知道如何处理它。

不幸的是(至少据我所知)无法发送 Popen 字符串,例如:

c = a + sql
subprocess.Popen(c)

除非您使用 shell=True,否则会得到响应。但是,您会得到返回语句而不是输出。

希望这能帮助和我有类似情况的人。

最佳答案

如果我明白你在问什么,那么你希望能够在 select 周围加上引号,并在流程周围转义单引号。

尝试使用 triple quotes :

line=""" "select (select count(*) from v$session)/(select value from v$parameter where name = \'processes\')*100 Percent from dual" """

...打印:

"select (select count(*) from v$session)/(select value from v$parameter where name = 'processes')*100 Percent from dual"

关于Python,引号中的引号,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8965937/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com