Як отримати позицію персонажа в Python?


527

Як я можу отримати положення персонажа всередині рядка в python?

Відповіді:


697

Є два способи струнних для цього, 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, де знайдений підрядковий підряд , такий, що підряд повністю міститься в 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])
Нейт

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

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

це так швидко, як це може бути? якщо один з використаних np.arrays може призвести до збільшення продуктивності для довгої str?
Себ

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
@arung: щоб отримати підрядку, використовуйте нарізку: str[from:to]де fromі toє індекси
Елі Бендерський,

s.find () return -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краще для такої речі.
o11c

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.