Подтвердить что ты не робот

Примеры поиска строк в Python

Я пытаюсь найти несколько примеров, но не повезло. Кто-нибудь знает некоторые примеры в сети? Я хотел бы знать, что он возвращает, когда он не может найти, и как указать от начала до конца, который, я думаю, будет 0, -1.

4b9b3361

Ответ 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.