对Python列表中的每个元素执行字符串操作

时间:2011-08-19 20:14:11

标签: python

我在python elements中有一个字符串元素列表,并希望编辑元素中的每个元素,因此我有一个新元素。请参阅下面的代码(它不起作用,但您会明白这一点):

for element in elements:
    element = "%" + element + "%"

有办法做到这一点吗?

7 个答案:

答案 0 :(得分:69)

elements = ['%{0}%'.format(element) for element in elements]

答案 1 :(得分:14)

您可以使用列表理解:

elements = ["%" + e + "%" for e in elements]

答案 2 :(得分:7)

您可以使用列表推导:

elements = ["%{}%".format(element) for element in elements]

答案 3 :(得分:2)

基本上有两种方法可以执行您想要的操作:编辑您拥有的列表,或者创建一个包含所需更改的新列表。目前在那里的所有答案都显示了如何使用列表理解(或map())来构建新列表,我同意这可能是要走的路。

另一种可能的方法是迭代列表并对其进行编辑。如果列表很大并且您只需要更改一些,则可以执行此操作。

for i, e in enumerate(elements):
    if want_to_change_this_element(e):
        elements[i] = "%{}%".format(e)

但正如我所说,我建议您使用列表理解答案之一。

答案 4 :(得分:0)

elements = map(lambda e : "%" + e + "%", elements)

答案 5 :(得分:0)

还有更多示例

char = ['g:','l:','q:']

使用替换

for i in range(len(char)):
    char[i] = char[i].replace(':', '')

使用地带

for i in range(len(char)):
    char[i] = char[i].strip(':')

使用功能

def list_cleaner(list_):
    return [char_.strip(':') for char_ in list_]


new_char = list_cleaner(char)
print(new_char)

使用Generator函数(如果您有大量数据,则建议这样做)

def generator_cleaner(list_):
    yield from (char_.strip(':') for char_ in list_)

# Prints all results in once
gen_char = list(generator_cleaner(char))

# Prints as much as you need, in this case only 8 chars
# I increase a bit the list so it makes more sense
char = ['g:', 'l:', 'q:', 'g:', 'l:', 'q:', 'g:', 'l:', 'q:']

# let's call our Generator Function
gen_char_ = generator_cleaner(char)

# We call only 8 chars
gen_char_ = [next(gen_char_) for _ in range(8)]
print(gen_char_)

答案 6 :(得分:0)

Python 3.6+ 版本(f 字符串):

elements = [f'%{e}%' for e in elements]