Як я можу отримати положення персонажа всередині рядка в python?
Як я можу отримати положення персонажа всередині рядка в python?
Відповіді:
Є два способи струнних для цього, 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
string.find(s, sub[, start[, end]])
Поверніть найнижчий індекс у s, де знайдений підрядковий підряд , такий, що підряд повністю міститься вs[start:end]
. Повернення-1
невдачі. За замовчуванням для початку та кінця та інтерпретація негативних значень така ж, як і для фрагментів.
І:
string.index(s, sub[, start[, end]])
Як,find()
але піднімайте,ValueError
коли підрядка не знайдена.
Просто задля повноти, якщо вам потрібно знайти всі позиції символу в рядку, ви можете зробити наступне:
s = 'shak#spea#e'
c = '#'
print [pos for pos, char in enumerate(s) if char == c]
який повернеться [4, 9]
print( [pos for pos, char in enumerate(s) if char == c])
foo = ( [pos for pos, char in enumerate(s) if char == c])
додасть координати foo у формат списку. Я вважаю це дійсно корисним
>>> 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'
str[from:to]
де from
і to
є індекси
Тільки для завершення, якщо я хочу знайти розширення у імені файлу, щоб перевірити його, мені потрібно знайти останнє ".", У цьому випадку використовуйте 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("}")
.
Що відбувається, коли рядок містить дублікат символу? з мого досвіду роботи 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
краще для такої речі.
string.find(character)
string.index(character)
Можливо, ви хочете ознайомитися з документацією, щоб дізнатися, у чому різниця між ними.
Символ може з'являтися кілька разів у рядку. Наприклад, у рядку sentence
позиція e
is 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]
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]
Рішення з numpy для швидкого доступу до всіх індексів:
string_array = np.array(list(my_string))
char_indexes = np.where(string_array == 'C')