Как я могу получить положение символа внутри строки в 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, где подстрока sub найдена так, что sub полностью содержится в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')