I’ve met a problem with re module in Python 3.6.5. I have this pattern in my regular expression:
But when I run it, I’m getting a DeprecationWarning .
I searched for the problem on SO, and haven’t found the answer, actually — what should I use instead of d+ ? Just [0-9]+ or maybe something else?
Содержание
- 1 Answer 1
- 1 ответов
- Ответы (2)
1 Answer 1
Python 3 interprets string literals as Unicode strings, and therefore your d is treated as an escaped Unicode character.
Declare your RegEx pattern as a raw string instead by prepending r , as below:
This also means you can drop the escapes for
as well since these will just be parsed as newline characters by re .
Я получаю много предупреждений, как это в Python:
что они означают? И как я могу их исправить?
1 ответов
например, если вы хотите поместить символ табуляции в строку, вы должны сделать:
если вы хотите поместить символ в строке, вы должны использовать :
или используйте «сырую строку»:
вы не можете просто поставить обратные косые черты в строковых литералах, когда захотите. Обратного слеша не действует, когда не следуют допустимые escape-последовательности и новые версии Python печатают предупреждение об устаревании. Например A не является escape-последовательностью:
если ваша последовательность обратной косой черты случайно совпадает с одной из escape-последовательностей Python, но вы этого не хотели, это еще хуже.
поэтому вы всегда должны использовать необработанные строки или .
важно помнить, что строковый литерал по-прежнему является строковым литералом, даже если эта строка предназначен для использования в качестве регулярного выражения. синтаксис регулярного выражения Python поддерживает множество специальных последовательностей, которые начинаются с . Например A соответствует началу строки. Но!—9—> недопустимо в строковом литерале Python! Это недопустимо:
вместо этого, вы должны сделать это:
Docstrings еще один, чтобы помнить: docstrings также являются строковыми литералами и недопустимыми последовательности недопустимы в тоже комментарии! Используйте необработанные строки ( r»»». «»» ) для docstrings, если они содержат s.
1117 просмотра
2 ответа
2711 Репутация автора
Я получаю много предупреждений в Python:
Что они имеют в виду? И как я могу их исправить?
Ответы (2)
12 плюса
2711 Репутация автора
Например, если вы хотите поместить символ табуляции в строку, вы должны сделать:
Если вы хотите поместить литерал в строку, вы должны использовать :
Или используйте «необработанную строку»:
Вы не можете просто поставить обратную косую черту в строковых литералах, когда захотите. Обратная косая черта недопустима, если за ней не следует ни одна из допустимых escape-последовательностей, и более новые версии Python выводят предупреждение об устаревании . Например, A это не escape-последовательность:
Если ваша последовательность обратной косой черты случайно совпадает с одной из escape-последовательностей Python, но вы этого не имели в виду, это еще хуже.
Поэтому вы всегда должны использовать необработанные строки или .
Важно помнить, что строковый литерал все еще является строковым литералом, даже если эта строка предназначена для использования в качестве регулярного выражения. Синтаксис регулярных выражений Python поддерживает множество специальных последовательностей, которые начинаются с . Например, A соответствует началу строки. Но A недопустимо в строковом литерале Python! Это неверно:
Вместо этого вы должны сделать это:
Следует помнить еще одну строку: строки документации также являются строковыми литералами, а недопустимые последовательности также недопустимы в строках документации! Используйте необработанные строки ( r»»». «»» ) для строк документации, если они содержат символы.
0 плюса
942 Репутация автора
В качестве резюме ответа Шона Хаммонда (принимая во внимание только то, что мне было нужно в моем случае), чтобы избежать «PEP8: неверная escape-последовательность» в регулярном выражении, используйте символ ‘r’ перед строкой регулярного выражения:
Источник: