Я пытаюсь найти несколько примеров, но не повезло. Кто-нибудь знает некоторые примеры в сети? Я хотел бы знать, что он возвращает, когда он не может найти, и как указать от начала до конца, который, я думаю, будет 0, -1.
Примеры поиска строк в Python
Ответ 1
вы можете использовать str.index
:
>>> 'sdfasdf'.index('cc')
Traceback (most recent call last):
File "<pyshell#144>", line 1, in <module>
'sdfasdf'.index('cc')
ValueError: substring not found
>>> 'sdfasdf'.index('df')
1
Ответ 2
Я не уверен, что вы ищете, вы имеете в виду find()
?
>>> x = "Hello World"
>>> x.find('World')
6
>>> x.find('Aloha');
-1
Ответ 3
Из документации:
str.find(sub[, start[, end]])
Возвращает самый низкий индекс в строке, где подстрока находится внутри среза
s[start:end]
. Необязательные аргументы start и end интерпретируются как обозначения срезов. Верните-1
, если sub не найден.
Итак, несколько примеров:
>>> my_str = 'abcdefioshgoihgs sijsiojs '
>>> my_str.find('a')
0
>>> my_str.find('g')
10
>>> my_str.find('s', 11)
15
>>> my_str.find('s', 15)
15
>>> my_str.find('s', 16)
17
>>> my_str.find('s', 11, 14)
-1
Ответ 4
Честно говоря, это такая ситуация, когда я просто открываю Python в командной строке и начинаю возиться:
>>> x = "Dana Larose is playing with find()"
>>> x.find("Dana")
0
>>> x.find("ana")
1
>>> x.find("La")
5
>>> x.find("La", 6)
-1
Интерпретатор Python упрощает подобные эксперименты. (То же самое касается других языков с аналогичным интерпретатором)
Ответ 5
Если вы хотите найти последний экземпляр строки в тексте, вы можете запустить rfind.
Пример:
s="Hello"
print s.rfind('l')
вывод: 3
* не требуется импорт
Полный синтаксис:
stringEx.rfind(substr, beg=0, end=len(stringEx))
Ответ 6
find( sub[, start[, end]])
Возвращает самый нижний индекс в строке, где находится подстрока sub, так что sub содержится в диапазоне [start, end]. Дополнительные аргументы start и end интерпретируются как в нотации среза. Возврат -1, если sub не найден.
От документы.
Ответ 7
Попробуйте следующее:
with open(file_dmp_path, 'rb') as file:
fsize = bsize = os.path.getsize(file_dmp_path)
word_len = len(SEARCH_WORD)
while True:
p = file.read(bsize).find(SEARCH_WORD)
if p > -1:
pos_dec = file.tell() - (bsize - p)
file.seek(pos_dec + word_len)
bsize = fsize - file.tell()
if file.tell() < fsize:
seek = file.tell() - word_len + 1
file.seek(seek)
else:
break
Ответ 8
если x - строка, и вы ищете y, которая также является строкой, это два случая: case 1: y существует в x, поэтому x.find(y)= индекс (позиция) y в x. случай 2: y не существует, поэтому x.find(y)= -1 это среднее значение y не найдено в x.