Как получить положение персонажа в Python?


528

Как я могу получить положение символа внутри строки в Python?

Ответы:


699

Для этого есть два строковых метода, find()и index(). Разница между ними заключается в том, что происходит, когда строка поиска не найдена. find()возвращается -1 и index()поднимает ValueError.

С помощью find()

>>> myString = 'Position of a character'
>>> myString.find('s')
2
>>> myString.find('x')
-1

С помощью index()

>>> myString = 'Position of a character'
>>> myString.index('s')
2
>>> myString.index('x')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: substring not found

Из руководства по Python

string.find(s, sub[, start[, end]])
Вернуть самый низкий индекс в s, где подстрока sub найдена так, что sub полностью содержится в s[start:end]. Возврат -1при неудаче. Значения по умолчанию для начала и конца и интерпретация отрицательных значений такие же, как для срезов.

А также:

string.index(s, sub[, start[, end]])
Как, find()но поднять, ValueErrorкогда подстрока не найдена.


127

Для полноты картины, если вам нужно найти все позиции символа в строке, вы можете сделать следующее:

s = 'shak#spea#e'
c = '#'
print [pos for pos, char in enumerate(s) if char == c]

который вернется [4, 9]


4
В python3 я получаю синтаксическую ошибку - как это следует изменить?
Шон

19
@Sean: оператор печати был удален. Остается только форма функции. Раздражает, но ответ заключается в том, чтобы просто изменить эту последнюю строку на: print( [pos for pos, char in enumerate(s) if char == c])
The Nate

3
foo = ( [pos for pos, char in enumerate(s) if char == c])поместит координаты foo в формате списка. Я нахожу это действительно полезным
3nrique0

это 0 проиндексировано, 0123 в отличие от 1234, поэтому фактическая позиция 5, 10
3kstc

это так быстро, как это может быть? если бы кто-то использовал np.arrays, может ли быть увеличение производительности для длинных строк?
Себ

49
>>> s="mystring"
>>> s.index("r")
4
>>> s.find("r")
4

"Долгий" путь

>>> for i,c in enumerate(s):
...   if "r"==c: print i
...
4

получить подстроку,

>>> s="mystring"
>>> s[4:10]
'ring'

1
Спасибо. Скажите, как мы можем получить подстроку строки в соответствии с указанными позициями ...
user244470

1
@arung: чтобы получить подстроку, используйте нарезку: str[from:to]где fromи toкакие индексы
Эли Бендерский,

s.find () возвращает -1, если подстрока не найдена
Евгений

s.search () вызывает ошибку ValueError, когда подстрока не найдена. s.find () возвращает -1, если подстрока не найдена.
Пракситель

16

Просто для завершения, в случае, если я хочу найти расширение в имени файла, чтобы проверить его, мне нужно найти последний '.', В этом случае используйте rfind:

path = 'toto.titi.tata..xls'
path.find('.')
4
path.rfind('.')
15

в моем случае я использую следующее, которое работает независимо от полного имени файла:

filename_without_extension = complete_name[:complete_name.rfind('.')]

Это полезно для определения длины строки. Например, поиск словаря может быть: left = q.find("{"); right = q.rfind("}").
ximiki

15

Что происходит, когда строка содержит повторяющийся символ? Исходя из моего опыта с, index()я увидел, что для дубликата вы получаете тот же индекс.

Например:

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

enumerateлучше для такого рода вещей.
О11с

10
string.find(character)  
string.index(character)  

Возможно, вы хотели бы взглянуть на документацию, чтобы узнать, в чем разница между ними.


Из этой связанной документации: s.search () вызывает ValueError, когда подстрока не найдена. s.find () возвращает -1, если подстрока не найдена.
Пракситель

7

Символ может появляться несколько раз в строке. Например, в строке sentenceпозиция eis 1, 4, 7(потому что индексирование обычно начинается с нуля). но я нахожу обе функции 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]

1

more_itertools.locate это сторонний инструмент, который находит все признаки предметов, которые удовлетворяют условию.

Здесь мы находим все индексные местоположения буквы "i".

import more_itertools as mit


s = "supercalifragilisticexpialidocious"
list(mit.locate(s, lambda x: x == "i"))
# [8, 13, 15, 18, 23, 26, 30]

0

Решение с NumPy для быстрого доступа ко всем индексам:

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

4
Пожалуйста, не используйте этот метод. Нет смысла вводить numpy в простую операцию индексации строк.
Майк Холлер
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.