gpt4 book ai didi

python - str.join() 向我的变量添加反斜杠

转载 作者:太空宇宙 更新时间:2023-11-04 07:05:58 24 4
gpt4 key购买 nike

我正在使用 Python 3.5 和 PyCharm 2017.3

我的代码如下所示:

var1 = 'ASD'
var2 = 'ASDPO'
qryPwr = ''.join(['select DATE as "DATE"'
' from Table1 where MKT = ', "'", var1, "'",
' and COMP = ', "'", var2, "'",
' and ppow_vdays = 0'
' and PPOW_SETTLE = ', "'", 'S', "'"])

我得到以下 qryPqr:

qryPwr 
'select DATE as "DATE", from Table1 where MKT = \'ASD\' and COMP = \'ASDPO\' and ppow_vdays = 0 and PPOW_SETTLE = \'S\''

所以,我有两个问题:

(1) 为什么到处都是反斜杠?

(2) 我如何摆脱它们或使我的连接语句更好?

编辑:我想从 print 语句中删除反斜杠,因为当我使用 qryPwr 进行数据库查询时,它会尝试使用反斜杠运行查询,因此会出错。

最佳答案

变量中没有反斜杠,它们只出现在打印输出中。

shell 不直接打印变量,而是调用repr()在上面。这个功能

makes an attempt to return a string that would yield an object with the same value when passed to eval()

通常,repr 只是将字符串用引号引起来:

>>> "abc" # actually calls repr("abc")
'abc'

如果您的字符串包含一种引号,它会使用另一种引号:

>>> "ab'c"
"ab'c"
>>> 'ab"c'
'ab"c'

但是您的字符串包含两种引号。如果您想在代码中指定它,您可以加入每个只有一种的字符串文字(就像您所做的那样),或者转义一种:

>>> "a\"b'c"
'a"b\'c'
>>> 'a"b\'c'
'a"b\'c'

当您将变量的字符串表示形式输出到命令行时,这种转义正是 repr 所做的。

旁注:您正在通过连接固定部分和(用户提供的?)变量来构建 SQL 查询。 请不要那样做。请至少使用准备好的语句,或者更好的包装库,如 SQLAlchemy .这不仅使处理数据库连接变得更加容易,而且更加安全。

关于python - str.join() 向我的变量添加反斜杠,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47696911/

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