我写了一个函数来创建SQL查询的VALUES
部分:
def query_values(data_iterator):
return ',\n'.join('\n({})\n'.format(',\n'.join('"{}"'.format(value) for value in data_row)
) for data_row in data_iterator
),
当我调用此函数和print
结果时,我得到的是:
query_values:
('\n("801",\n"printer",\n"barcode printer")\n,\n\n("844",\n"laptop",\n"windows")\n,\n\n("997",\n"printer",\n"barcode printer")\n',)
全部在一条线上。而不是打破线,显示\n
。
最初我有一个\n
,但后来我插入了多个,只是为了看看它们是否会显示出来。
第二个问题是整个事物都有括号,我不想要。
我对这两个问题感到困惑,我想到了第二个问题的解决方案:
我在函数的末尾有一个逗号。逗号导致函数返回元组,而不是单个字符串。
我删除了逗号:
def query_values(data_iterator):
return ',\n'.join('\n({})\n'.format(',\n'.join('"{}"'.format(value) for value in data_row)
) for data_row in data_iterator
)
并解决了这两个问题。输出现在是:
query_values:
("801",
"printer",
"barcode printer")
,
("844",
"laptop",
"windows")
,
("997",
"printer",
"barcode printer")
我把逗号放回去,显示了\n
。我删除了逗号,我又有了多行。
我删除了无关的\n
,所以现在我得到了我想要的东西:
query_values:
("801","printer","barcode printer"),
("844","laptop","windows"),
("997","printer","barcode printer")
所以,我的代码工作正常,但我对旧版本代码中显示的\n
字符感到困惑。为什么会这样?
更新:这个问题的几个答案集中在为什么我得到一个元组。那不是我的问题。为什么要展示/n
?
看来这是元组的行为。打印元组时,打印在每个元素上调用__repr()__
。列表也是如此。
我试过这个:
tup = "xxx\nxx",
lst =["xxx\nxx"]
for t in tup,lst:
print('t :', t)
for s in t:
print('element:',s)
print(' repr:',s.__repr__())
print('---')
输出是:
t : ('xxx\nxx',)
element: xxx
xx
repr: 'xxx\nxx'
---
t : ['xxx\nxx']
element: xxx
xx
repr: 'xxx\nxx'
---
因此,元组和列表的行为相同。
当我们有一个字符串时,调用__repr__()
不会扩展\n
字符,并在其周围加上引号:
s = "xxx\nxx"
print('s :', s)
print('s.__repr__():', s.__repr__())
输出:
s : xxx
xx
s.__repr__(): 'xxx\nxx'
running.t,interjay和Daniel Roseman在评论中提到了这种元组行为,但在答案中没有提到,这就是我发布这个答案的原因。
编写return something,
与return (something,)
相同:它返回一个包含一个元素的元组。当你print
这个时,它将显示元组的外括号,并且里面的字符串将被打印为其源代码表示,即带有转义码和内部引号。
但是,return something
只返回该值,然后可以正常打印。
这似乎是Python中元组的行为。您可以使用更简单的情况对此进行测试:
>>> print ("xxx\n\nx",)
('xxx\n\nx',)
看起来像Python可以帮助您进行调试并在打印时转义字符串中的所有命令序列,因此字符串的显示方式与它们的定义方式相同。
虽然这确实让你感到困惑,但有趣的是。 :)
元组可以用括号表示,也可以用不用括号表示,逗号决定类型。
>>> t = 1, 'a', 'abc'
>>> type(t)
<type 'tuple'>
>>> t
(1, 'a', 'abc')
>>>
在上面的例子中,你在字符串之后添加了一个尾随逗号,而python将它解释为一个元组。
检查这个link。
>>> t= 'a',
>>> type(t)
<type 'tuple'>
>>> t
('a',)
>>> t = 'a'
>>> type(t)
<type 'str'>
>>> t
'a'