如何在Python中获取字符串中字符的位置?


当前回答

当字符串包含重复字符时会发生什么? 从我使用index()的经验来看,对于duplicate,你会得到相同的索引。

例如:

s = 'abccde'
for c in s:
    print('%s, %d' % (c, s.index(c)))

将返回:

a, 0
b, 1
c, 2
c, 2
d, 4

在这种情况下,你可以这样做:

for i, character in enumerate(my_string):
   # i is the position of the character in the string

其他回答

当字符串包含重复字符时会发生什么? 从我使用index()的经验来看,对于duplicate,你会得到相同的索引。

例如:

s = 'abccde'
for c in s:
    print('%s, %d' % (c, s.index(c)))

将返回:

a, 0
b, 1
c, 2
c, 2
d, 4

在这种情况下,你可以这样做:

for i, character in enumerate(my_string):
   # i is the position of the character in the string

使用numpy快速访问所有索引的解决方案:

string_array = np.array(list(my_string))
char_indexes = np.where(string_array == 'C')

一个字符可能在字符串中出现多次。例如,在一个字符串句子中,e的位置是1,4,7(因为索引通常从0开始)。但我发现find()和index()函数都返回字符的第一个位置。所以,这个问题可以这样解决:

def charposition(string, char):
    pos = [] #list to store positions for each 'char' in 'string'
    for n in range(len(string)):
        if string[n] == char:
            pos.append(n)
    return pos

s = "sentence"
print(charposition(s, 'e')) 

#Output: [1, 4, 7]

如果你想找到第一个匹配。

Python有一个内置的字符串方法来完成这项工作:index()。

string.index(value, start, end)

地点:

值:(必选)要搜索的值。 start:(可选)从哪里开始搜索。默认值为0。 end:(可选)结束搜索的位置。Default是到字符串的末尾。

def character_index():
    string = "Hello World! This is an example sentence with no meaning."
    match = "i"
    return string.index(match)
        
print(character_index())
> 15

如果你想找到所有的匹配项。

假设你需要所有字符匹配的索引,而不仅仅是第一个。

python的方法是使用enumerate()。

def character_indexes():
    string = "Hello World! This is an example sentence with no meaning."
    match = "i"

    indexes_of_match = []

    for index, character in enumerate(string):
        if character == match:
            indexes_of_match.append(index)
    return indexes_of_match

print(character_indexes())
# [15, 18, 42, 53]

或者更好的是一个列表理解:

def character_indexes_comprehension():
    string = "Hello World! This is an example sentence with no meaning."
    match = "i"

    return [index for index, character in enumerate(string) if character == match]


print(character_indexes_comprehension())
# [15, 18, 42, 53]
string.find(character)  
string.index(character)  

也许您想查看一下文档,以找出两者之间的区别。