Как сделать проверку на пустую строку python
Синтаксис Python во многом похож на Perl, C и Java. Однако между языками есть определенные различия.
Содержание
Первая программа на Python
Давайте выполним программы в разных режимах программирования.
Программирование в интерактивном режиме
Вызов интерпретатора без передачи файла сценария в качестве параметра вызывает следующую подсказку:
Введите следующий текст в командной строке Python и нажмите Enter:
Если вы используете новую версию Python, вам нужно будет использовать оператор печати со скобками, как print ("Привет, Python!"); Однако в версии Python 2.4.3 это дает следующий результат:
Программирование в режиме написания сценариев
Вызов интерпретатора с параметром написания сценариев начинает выполнение сценария и продолжается, пока сценарий не будет завершен. Когда сценарий завершен, интерпретатор больше не активен.
Давайте создадим простую программу Python в сценарии. Файлы Python имеют расширение .py. Введите следующий исходный код в файл test.py:
Это дает следующий результат:
Давайте попробуем другой способ выполнить скрипт Python. Вот модифицированный файл test.py:
Предполагается, что у вас есть интерпретатор Python в каталоге /usr/bin. Теперь попробуйте запустить эту программу следующим образом:
Это дает следующий результат:
Идентификаторы Python
Идентификатор Python — это имя, используемое для идентификации переменной, функции, класса, модуля или другого объекта. Идентификатор Python начинается с буквы от A до Z, от a до z или символа подчеркивания (_), за которым следуют ноль или более букв, символов подчеркивания и цифр (от 0 до 9).
Python не допускает символов пунктуации, таких как @, $ и%, в идентификаторах. Python — это язык программирования с учетом регистра, таким образом, Manpower и manpower — это два разных идентификатора в Python.
Далее приведены соглашения по присвоению имен для идентификаторов Python:
- Имена классов начинаются с заглавной буквы. Все остальные идентификаторы начинаются со строчной буквы.
- Начало идентификатора с одного символа подчеркивания в начале указывает на то, что идентификатор является частным.
- Начало идентификатора с двумя символами подчеркивания указывает на строго частный идентификатор.
- Если идентификатор также заканчивается двумя символами подчеркивания, идентификатор является специальным именем, определяемым стандартом языка программирования.
Зарезервированные слова
В следующем списке показаны ключевые слова Python. Это зарезервированные слова, и вы не можете использовать их для имен констант, переменных или любых других идентификаторов. Все ключевые слова Python содержат только строчные буквы.
Ключевые слова | ||
and | exec | not |
assert | finally | or |
break | for | pass |
class | from | |
continue | global | raise |
def | if | return |
del | import | try |
elif | in | while |
else | is | with |
except | lambda | yield |
Линии и отступы в Python
Python не требует фигурных скобок для обозначения блоков кода для определений классов и функций или управления потоком. Блоки кода обозначаются строковым отступом, который строго соблюдается.
Количество пробелов в отступе может меняться, но все операторы в блоке должны иметь одинаковый отступ Python. Например:
Однако следующий блок генерирует ошибку:
Таким образом, в Python все непрерывные строки с одинаковым количеством пробелов образуют блок. В следующем примере есть различные блоки операторов.
Примечание: не пытайтесь понять логику на данном этапе. Просто убедитесь, что вы различаете блоки, даже если они не имеют скобок.
Многострочные операторы
Операторы в Python обычно заканчиваются новой строкой. Однако Python позволяет использовать символ продолжения строки (\) для обозначения продолжения строки. Например:
Для операторов, заключенных в квадратные скобки [], <> или (), не нужно использовать символ продолжения строки. Например:
Цитирование в Python
Python принимает одинарные ('), двойные (") и тройные (''' или""") кавычки для обозначения строковых литералов до тех пор, пока один и тот же тип кавычек начинается и заканчивается в строке.
Тройные кавычки используются для разделения строки на несколько строк. Например, все следующие строки являются корректными:
Комментарии в Python
Это дает следующий результат:
Это однострочный комментарий. Вы можете ввести комментарий в той же строке после оператора или выражения:
Вы можете прокомментировать несколько строк следующим образом:
Следующая строка в тройных кавычках также игнорируется интерпретатором и может использоваться как многострочный комментарий Python:
Использование пустых строк в Python
Строка, содержащая только пробелы, возможно с комментарием, называется пустой строкой, и Python полностью ее игнорирует.
В сеансе интерактивного интерпретатора вы должны ввести пустую физическую строку для завершения многострочного оператора.
Ожидание пользователя
Здесь "\n\n" используется для создания двух новых строк перед отображением фактической строки. Как только пользователь нажимает клавишу, программа завершается. Это хороший способ, позволяющий держать окно консоли открытым до тех пор, пока пользователь не закончит работу с приложением.
Несколько операторов в одной строке
Точка с запятой (;) позволяет размещать несколько операторов в одной строке, если ни одна из них не запускает новый блок кода. Вот пример фрагмента кода с точкой с запятой:
Несколько групп операторов в виде наборов
Группа отдельных операторов, составляющих один блок кода, в Python называется набором. Для составных или сложных операторов, таких как if, while, def и class, требуется строка заголовка и набор.
Строки заголовка начинаются с оператора (с ключевого слова) и заканчиваются двоеточием (:), за которыми следуют одна или несколько строк, составляющих набор. Например:
Аргументы командной строки
Многие программы могут быть запущены, чтобы предоставить вам некоторую базовую информацию о том, как их следует запускать. Python позволяет сделать это с помощью -h:
Вы также можете запрограммировать свой сценарий таким образом, чтобы он принимал различные параметры. Аргументы командной строки — это сложная тема, и ее следует изучить чуть позже, когда вы ознакомитесь с остальными концепциями Python, чтобы создать первую программу на Pythonе для начинающих.
Есть ли в Python что-то вроде пустой строковой переменной, где вы можете сделать:
Независимо от того, какой самый элегантный способ проверить пустые строковые значения? Я нахожу жесткое кодирование "" каждый раз для проверки пустой строки не таким хорошим.
Пустые строки "falsy" , что означает, что они считаются ложными в булевом контексте, поэтому вы можете просто сделать это:
Это предпочтительный способ, если вы знаете, что ваша переменная является строкой. Если вашей переменной может быть и другой тип, вы должны использовать myString == "" . См. Документацию по Truth Value Testing для других значений, которые являются ложными в булевых контекстах.
Для последовательностей (строки, списки, кортежи) используйте тот факт, что пустые последовательности являются ложными.
Итак, вы должны использовать:
Чтобы уточнить, последовательности оцениваются до False или True в булевом контексте, если они пусты или нет. Они не равны до False или True .
Самый элегантный способ, вероятно, состоял бы в том, чтобы просто проверить, действительно ли его истина или ложь, например:
Однако вы можете удалить пробел, потому что:
Вероятно, вы должны быть немного более явными в этом, если вы точно не знаете, что эта строка прошла какую-то проверку и представляет собой строку, которая может быть проверена таким образом.
Я проверил бы несоответствие перед снятием. Кроме того, я бы использовал тот факт, что пустые строки являются False (или Falsy). Этот подход похож на Apache StringUtils.isBlank или Guava Strings.isNullOrEmpty
Это то, что я хотел бы использовать, чтобы проверить, нет ли строки ни ИЛИ ИЛИ Пусто или Пусто:
И, полная противоположность тестированию, если строка не является None NOR Empty NOR Blank:
Более сжатые формы приведенного выше кода:
Однажды я написал что-то похожее на ответ Бартека и вдохновил javascript:
Проверить пустую или пустую строку (более короткий путь):
Если вы хотите различать пустые и нулевые строки, я бы предложил использовать if len(string) , иначе я бы предложил просто if string , как говорили другие. Предупреждение о строках, заполненных пробелами, все равно применяется, поэтому не забудьте strip .
Я думаю, что это то, к чему пытался добраться оригинальный постер. что-то, что читается как можно ближе к английскому и соответствует строгой практике программирования.
Персонаж за характером Я думаю, что это хорошее решение.
Я отметил, что None не вступил в обсуждение, поэтому, добавив это и сжимая дальше, мы получим:
Единственный действительно надежный способ сделать это заключается в следующем:
У всех других решений есть возможные проблемы и крайние случаи, когда проверка может потерпеть неудачу.
len(myString)==0 может завершиться ошибкой, если myString является объектом класса, который наследуется от str и переопределяет метод __len__() .
Аналогичным образом myString == "" и myString.__eq__("") могут завершиться ошибкой, если myString переопределяет __eq__() и __ne__() .
По какой-то причине "" == myString также одурачивается, если myString переопределяет __eq__() .
myString is "" и "" is myString эквивалентны. Они оба потерпят неудачу, если myString самом деле не строка, а подкласс строки (оба возвращают False ). Кроме того, поскольку они являются проверками идентичности, единственная причина, по которой они работают, заключается в том, что Python использует String Pooling (также называемый String Internment), который использует тот же экземпляр строки, если он интернирован (см. Здесь: Почему при сравнении строк используется либо '= = 'или' is 'иногда дают другой результат?). И "" интернируется с самого начала в CPython
Большая проблема с проверкой идентичности состоит в том, что String Internment (насколько я мог найти) не стандартизирует, какие строки интернированы. Это означает, что теоретически "" не обязательно интернироваться, и это зависит от реализации.
Единственный способ сделать это, который действительно не может быть одурачен, - это тот, который упоминался в начале: "".__eq__(myString) . Так как это явно вызывает метод __eq__() пустой строки, его нельзя одурачить, переопределив любые методы в myString, и он надежно работает с подклассами str .
Также полагаться на ложность строки может не сработать, если объект переопределяет __bool__() .
Это не только теоретическая работа, но на самом деле может иметь отношение к реальному использованию, так как я уже видел, как фреймворки и библиотеки, подклассифицирующие str ранее, и использование myString is "" могут возвращать неверный вывод.
Кроме того, сравнение строк, используя is в целом является довольно злой ловушкой, так как он будет работать правильно, иногда, но не в другое время, так как строка Пулы следует довольно странным правилам.
Тем не менее, в большинстве случаев все упомянутые решения будут работать правильно. Это пост в основном академическая работа.
Тип строки Python предоставляет множество функций, которые влияют на использование заглавных букв в строке. Они включают :
- str.casefold
- str.upper
- str.lower
- str.capitalize
- str.title
- str.swapcase
С юникод строк (по умолчанию в Python 3), эти операции не являются 1: 1 отображения или обратимым. Большинство из этих операций предназначены для отображения, а не нормализации. str.casefold()
str.casefold создает строчную строку, которая подходит для случая нечувствительных сравнений. Это более агрессивный , чем str.lower и может изменить строки, которые уже находятся в нижнем регистре или вызывают строки , чтобы расти в длину, и не предназначена для отображения.
Преобразования, которые происходят в рамках casefolding, определяются Консорциумом Unicode в файле CaseFolding.txt на их веб-сайте. str.upper()
str.upper принимает каждый символ в строке и преобразует его в верхнем регистре эквивалента, например:
str.lower делает обратное; он берет каждый символ в строке и преобразует его в строчный эквивалент:
str.capitalize возвращает заглавную версию строки, то есть, он делает первый символ имеет верхний регистр , а остальные нижние:
str.title возвращает название обсаженной версии строки, то есть, каждая буква в начале слова производится в верхнем регистре , а все остальные сделаны в нижнем регистре:
str.swapcase возвращает новый объект строки , в которой все строчные символы поменяны местами в верхний регистр и все символы верхнего регистра в нижний:
Использование в качестве str методов класса
Следует отметить , что эти методы могут быть названы либо на струнных объектов (как показано выше) или как метод класса от str класса (с явным вызовом str.upper и т.д.)
Это особенно полезно при применении одного из этих методов для многих строк сразу, скажем, на map функции.
Разбить строку на основе разделителя на список строк
str.split принимает строку и возвращает список подстрок исходной строки. Поведение отличается в зависимости от того sep предусмотрен или опущен аргумент.
Если sep не предусмотрен, или нет None , то происходит расщепление везде , где есть пробела. Однако начальные и конечные пробелы игнорируются, и несколько последовательных пробельных символов обрабатываются так же, как один пробельный символ:
sep параметр может быть использован для определения строки разделителей. Исходная строка разделяется там, где встречается строка-разделитель, а сам разделитель отбрасывается. Несколько последовательных разделители не обрабатываются так же , как однократный, а вызвать пустые строки , которые будут созданы.
По умолчанию заключается в разделении на каждом появлении разделителя, однако maxsplit параметр ограничивает количество расщеплений , которые происходят. Значение по умолчанию -1 означает , что нет предела:
Примечание: Python определяет максимальное число разделений , выполняемых, в то время как большинство других языков программирования указать максимальное количество подстрок созданных. Это может создать путаницу при переносе или сравнении кода.
Заменить все вхождения одной подстроки другой подстрокой
Пайтона str типа также есть метод для замены вхождений одной подстроки с другой подстроки в заданной строке. Для более сложных случаев можно использовать re.sub . str.replace(old, new[, count]) :
str.replace принимает два аргумента , old и new , содержащий old подстроку , которая должна быть заменена на new подстроку. Необязательный аргумент count определяет число замен , чтобы быть:
Например, для того , чтобы заменить 'foo' с 'spam' в следующей строке, мы можем назвать str.replace с old = 'foo' и new = 'spam' :
Если данная строка содержит несколько примеров , которые соответствуют old аргументу, все вхождения заменяются значением подаваемого в new :
если, конечно, мы не поставляем значение для count . В этом случае count вхождения собираются заменяются:
str.format и f-strings: форматировать значения в строку
Python обеспечивает интерполяцию строки и функциональность форматирования через str.format функции, введенной в версии 2.6 и F-строк , введенных в версии 3.6.
Даны следующие переменные:
Следующие утверждения все эквивалентны
Для справки, Python также поддерживает классификаторы в стиле C для форматирования строк. Примеры , приведенные ниже, эквивалентны тем , которые выше, но str.format вариантов являются предпочтительными из - за преимущества в гибкости, последовательности обозначений и расширяемости:
Скобки используются для интерполяции в str.format также может быть пронумерована для уменьшения дублирования при форматировании строк. Например, следующее эквивалентно:
В то время как официальная документация питона, как обычно, достаточно тщательно, pyformat.info имеет большой набор примеров с подробными объяснениями.
Кроме того, < и >символы могут быть экранированы с помощью двойных скобок:
См Строка форматирования для получения дополнительной информации. str.format() был предложен в PEP 3101 и F-строк в PEP 498 .
Подсчет количества появлений подстроки в строке
Один метод доступен для подсчета количества вхождений подстроки в другой строки, str.count . str.count(sub[, start[, end]])
str.count возвращает int , указывающее количество неперекрывающихся вхождений подстрок sub в другой строке. Необязательные аргументы start и end указывают на начало и конец , в котором поиск будет происходить. По умолчанию start = 0 и end = len(str) означает всю строку будет искать:
Задавая различные значения для start , end , мы можем получить более локализованный поиск и сосчитать, например, если start равно 13 призыва к:
Проверьте начальный и конечный символы строки
Для того , чтобы проверить начало и окончание данной строки в Python, можно использовать методы str.startswith() и str.endswith() . str.startswith(prefix[, start[, end]])
Как следует это имя, str.startswith используется для проверки , начинается ли заданная строка с заданными символами в prefix .
Необязательные аргументы start и end указать начальную и конечную точки , из которых тестирование будет начать и закончить. В следующем примере, указав начальное значение 2 наша строка будет просматриваться с позиции 2 , а затем:
Это дает True , так как s[2] == 'i' и s[3] == 's' .
Вы можете также использовать tuple , чтобы проверить , если он начинается с какой - либо из набора строк
str.endswith(prefix[, start[, end]])
str.endswith точно похож на str.startswith с той лишь разницей, что он ищет окончание символов и не начиная символов. Например, чтобы проверить, заканчивается ли строка полной остановкой, можно написать:
как и с startswith более одного символа может использоваться как окончание последовательности:
Вы можете также использовать tuple , чтобы проверить , если он заканчивается любой из набора строк
Проверка того, из чего состоит строка
Пайтона str тип также имеет целый ряд методов , которые могут быть использованы для оценки содержимого строки. Это str.isalpha , str.isdigit , str.isalnum , str.isspace . Капитализация может быть проверена с str.isupper , str.islower и str.istitle . str.isalpha
str.isalpha не принимает никаких аргументов и возвращает True , если все символы в данной строке являются буквенными, например:
В краевой случае пустая строка вычисляет значение False при использовании "".isalpha() . str.isupper , str.islower , str.istitle
Эти методы проверяют использование заглавных букв в заданной строке.
str.isupper это метод , который возвращает True , если все символы в данной строке в верхнем регистре и False иначе.
С другой стороны , str.islower это метод , который возвращает True , если все символы в данной строке в нижнем регистре и False иначе.
str.istitle возвращает True , если данная строка названия обсаженное; то есть каждое слово начинается с заглавной буквы, за которой следуют строчные буквы.
str.isdecimal , str.isdigit , str.isnumeric
str.isdecimal возвращает строка , является ли последовательность десятичных цифр, пригодная для представления десятичного числа.
str.isdigit включает в себя цифру не в форме , подходящей для представления десятичного числа, такие , как надстрочные цифры.
str.isnumeric включает в себя любые числовые значения, даже если не цифры, такие как значения вне диапазона 0-9.
Байтовые строки ( bytes в Python 3, str в Python 2), поддерживает только isdigit , который проверяет только основные ASCII цифр.
Как str.isalpha пустая строка вычисляет значение False . str.isalnum
Это сочетание str.isalpha и str.isnumeric , в частности , он имеет значение True , если все символы в данной строке являются буквенно - цифровыми, то есть они состоят из буквенных или цифровых символов:
Возвращает True , если строка содержит только пробельные символы.
Чтобы покрыть этот случай нам нужен дополнительный тест
Но самый короткий путь , чтобы проверить , если строка пуста или содержит только пробельные символы, чтобы использовать strip (без аргументов она удаляет все начальные и конечные пробельные символы)
str.translate: перевод символов в строке
Python поддерживает translate метод на str типа , который позволяет указать таблицу преобразования (используется для замены), а также любые символы , которые должны быть удалены в процессе.
параметр Описание table Это таблица поиска, которая определяет отображение от одного символа к другому. deletechars Список символов, которые должны быть удалены из строки.
maketrans метод ( str.maketrans в Python 3 и string.maketrans в Python 2) позволяет создать таблицу перевода.
translate метод возвращает строку , которая является переведенной копией исходной строки.
Вы можете установить table аргумент None , если требуется только для удаления символов.
Удаление нежелательных начальных / конечных символов из строки
Три метода при условии , что предлагают возможность раздеться начальные и конечные символы из строки: str.strip , str.rstrip и str.lstrip . Все три метода имеют одинаковую подпись, и все три возвращают новый строковый объект с удаленными нежелательными символами. str.strip([chars])
str.strip действует на заданной строки и удаляет (полоски) или каких - либо ведущих задних символов , содержащихся в аргументе chars ; если chars не входит в комплект или нет None , все пробельные символы удаляются по умолчанию. Например:
Если chars поставляются, все символы , содержащиеся в нем, удаляются из строки, которая возвращается. Например:
str.rstrip([chars]) и str.lstrip([chars])
Эти методы имеют ту же семантику и аргументы с str.strip() , их отличие заключается в том направлении , откуда они начинаются. str.rstrip() начинается с конца строки в то время как str.lstrip() расщепляется с начала строки.
Например, при использовании str.rstrip :
В то время как, используя str.lstrip :
Сравнение строк без учета регистра
Сравнение строки без учета регистра кажется чем-то тривиальным, но это не так. В этом разделе рассматриваются только строки Unicode (по умолчанию в Python 3). Обратите внимание, что Python 2 может иметь незначительные недостатки по сравнению с Python 3 - более поздняя обработка юникода гораздо более полная.
Первое, на что следует обратить внимание, это то, что преобразования с удалением регистра в юникоде не являются тривиальными. Существует текст , для которого text.lower() != text.upper().lower() , Например, "ß" :
Но предположим, что вы хотели регистронезависмо сравнивать "BUSSE" и "Buße" . Черт возьми, вы , вероятно , также хотят , чтобы сравнить "BUSSE" и "BUẞE" равный - это новая форма капитала. Рекомендуемый способ заключается в использовании casefold :
Не просто использовать lower . Если casefold не доступен, делая .upper().lower() помогает (но только немного).
Тогда вы должны рассмотреть акценты. Если визуализатор шрифт хорошо, вы , вероятно , думаете , "ê" == "ê" - но это не так :
Это потому что они на самом деле
Чтобы закончить, здесь это выражается в функциях:
Объединить список строк в одну строку
Строка может быть использована в качестве разделителя , чтобы присоединиться к списку строк вместе в одну строку с помощью join() метод. Например, вы можете создать строку, где каждый элемент в списке разделен пробелом.
В следующем примере строковые элементы разделяются тремя дефисами.
Полезные константы строкового модуля
Пайтона string модуль предоставляет константы для операций , связанных строк. Для того, чтобы использовать их, импортировать string модуля:
Стечение ascii_lowercase и ascii_uppercase :
Содержит все символы нижнего регистра ASCII:
Содержит все символы ASCII в верхнем регистре:
Содержит все десятичные цифры:
Содержит все шестнадцатеричные символы:
Содержит все восьмеричные символы:
Содержит все символы , которые считаются знаки препинания в C локали:
Содержит все символы ASCII, которые считаются пробелами:
В режиме сценария, print(string.whitespace) напечатает фактические символы, используйте str , чтобы получить вернулся выше строка. string.printable :
Содержит все символы, которые считаются печатными; сочетание string.digits , string.ascii_letters , string.punctuation и string.whitespace .
Сторнирование строки
Строка может реверсировать с использованием встроенных в reversed() функции, которая принимает строку и возвращает итератор в обратном порядке.
reversed() могут быть обернуты в вызове ''.join() , чтобы сделать строку из итератора.
В то время как с использованием reversed() может быть более удобными для чтения для непосвященных пользователей Python, используя расширенную нарезку с шагом -1 быстрее и более кратким. Вот, попробуйте реализовать это как функцию:
Обоснуйте строки
Python предоставляет функции для выравнивания строк, позволяя заполнять текст, чтобы упростить выравнивание различных строк.
Ниже приведен пример str.ljust и str.rjust :
40 -> 2555 миль (4112 км.) 19 -> 63 миль. (102 км.) 5 -> 1381 миль. (2222 км.) 93 -> 189 миль. (305 км.)
ljust и rjust очень похожи. Оба имеют width параметр и необязательный fillchar параметр. Любая строка , создаваемая эти функции, по крайней мере до тех пор , как width параметр , который был передан в функцию. Если строка длиннее , чем width alread, она не усекается. fillchar аргумент, который по умолчанию используется символ пробела ' ' должен быть один символ, а не multicharacter строка.
ljust функция подушечки конца строки она называется на с fillchar до тех пор, пока width длиной символов. rjust функция подушечки начала строки в подобной манере. Таким образом, l и r в названиях этих функций относятся к стороне , что исходная строка, а не fillchar , расположена в выходной строке.
Преобразование между str или байтовыми данными и символами юникода
В Python 2 вам может потребоваться преобразовать данные str в символы Unicode. По умолчанию ( '' , "" и т.д.) является строкой ASCII, с любыми значениями за пределами диапазона ASCII отображается в виде уцелевших значений. Unicode строки u'' (или u"" и т.д.).
Строка содержит
Python делает его чрезвычайно интуитивным, чтобы проверить, содержит ли строка заданную подстроку. Просто используйте in операторе:
Примечание: тестирование пустой строки всегда будет приводить True :
Синтаксис
Параметры
Примечания
Научим основам Python и Data Science на практике
Это не обычный теоритический курс, а онлайн-тренажер, с практикой на примерах рабочих задач, в котором вы можете учиться в любое удобное время 24/7. Вы получите реальный опыт, разрабатывая качественный код и анализируя реальные данные.
До сих пор мы обсуждали числа как стандартные типы данных в Python. В этом разделе учебника мы рассмотрим самый популярный тип данных в Python - строку.
Строка в Python - это набор символов, окруженных одинарными, двойными или тройными кавычками. Компьютер не понимает символы; внутри он хранит управляемый символ как комбинацию 0 и 1 .
Каждый символ кодируется в ASCII или Unicode. Поэтому можно сказать, что строки Python также называют коллекцией символов Unicode.
В Python строки можно создавать, заключая символ или последовательность символов в кавычки. Python позволяет нам использовать одинарные, двойные или тройные кавычки для создания строки.
Рассмотрим следующий пример на языке Python для создания строки.
Если мы проверим тип переменной str с помощью сценария Python print(type(str)) , то будет выведено:
В Python строки рассматриваются как последовательность символов, что означает, что Python не поддерживает символьный тип данных; вместо этого один символ, записанный как p , рассматривается как строка длины 1 .
Создание строки в Python
Мы можем создать строку, заключив символы в одинарные или двойные кавычки. Python также предоставляет тройные кавычки для представления строки, но они обычно используются для многострочных строк или документов.
Индексация и разбиение строк в Python
Как и в других языках, индексация строк в Python начинается с 0 . Например, строка "HELLO" индексируется так, как показано на рисунке ниже.
Рассмотрим следующий пример:
В Python мы можем использовать оператор : (двоеточие) для доступа к подстроке из заданной строки. Рассмотрим следующий пример.
Здесь мы должны заметить, что верхний диапазон, заданный в операторе slice , всегда является эксклюзивным, т.е. если задано str = 'HELLO' , то str[1:3] всегда будет включать str[1] = 'E' , str[2] = 'L' и ничего больше.
Рассмотрим следующий пример:
Мы можем сделать отрицательную нарезку в строке; она начинается с самого правого символа, который обозначается как -1 . Второй крайний правый индекс обозначает -2 , и так далее. Рассмотрим следующее изображение.
Рассмотрим следующий пример
Переназначение строк
Обновить содержимое строки так же просто, как присвоить его новой строке. Объект string не поддерживает присваивание элементов, т.е. строка может быть заменена только новой строкой, поскольку ее содержимое не может быть частично заменено. В Python строки неизменяемы.
Рассмотрим следующий пример.
Однако в примере 1 строка str может быть полностью присвоена новому содержимому, как указано в следующем примере.
Удаление строки в Python
Как мы знаем, строки неизменяемы. Мы не можем удалить или убрать символы из строки. Но мы можем удалить всю строку, используя ключевое слово del .
Пробуем удалить часть строки:
Теперь мы пробуем удалить всю строку:
Строковые операторы в Python
Оператор | Описание |
---|---|
+ | Ооператор конкатенации, используемый для соединения строк, заданных по обе стороны от оператора. |
* | Оператор повторения. Он объединяет несколько копий одной и той же строки. |
[] | Оператор среза. Он используется для доступа к подстрокам определенной строки. |
[:] | Оператор среза диапазона. Он используется для доступа к символам из указанного диапазона. |
in | Оператор членства. Он возвращает, присутствует ли определенная подстрока в указанной строке. |
not in | Оператором членства и выполняет прямо противоположное действие по отношению к in . Он возвращает true , если определенная подстрока отсутствует в указанной строке. |
r/R | Используется для указания необработанной строки. Необработанные строки используются в тех случаях, когда необходимо вывести фактическое значение управляющих символов, таких как C://python . Чтобы определить любую строку как необработанную, за строкой следует символ r или R . |
% | Он используется для форматирования строк. Он использует спецификаторы формата, применяемые в программировании на языке C , такие как %d или %f , для отображения их значений в python. |
Рассмотрим следующий пример, чтобы понять использование операторов Python.
Форматирование строк в Python
Экранирование последовательности
Допустим, нам нужно записать текст в виде - They said, "Hello what's going on?"- данное утверждение может быть записано в одинарных или двойных кавычках, но оно вызовет SyntaxError , так как содержит как одинарные, так и двойные кавычки.
Рассмотрим следующий пример, чтобы понять реальное использование операторов Python.
Мы можем использовать тройные кавычки для решения этой задачи, но Python предоставляет возможность экранировать нашу последовательнсть символов.
Символ обратной косой черты ( / ) обозначает escape последовательность. За обратной косой чертой может следовать специальный символ, который интерпретируется по-разному. Одинарные кавычки внутри строки должны быть экранированы. Мы можем применить то же самое, что и в случае с двойными кавычками.
Ниже приведен список управляющих последовательностей для экранирования:
Escape последовательность | Описание |
---|---|
\newline | Игнорирует новую строку. |
\\ | Обратный слэш |
\' | Одинарные кавычки |
\\'' | Двойные кавычки |
\a | ASCII гудок |
\b | ASCII Backspace(BS) |
\f | ASCII Formfeed (смещение к началу след. страницы) |
\n | ASCII Linefeed (перевод на след. строку) |
\r | ASCII Carriege Return(CR) (перемещение курсора к левому краю поля) |
\t | ASCII горизонтальная табуляция |
\v | ASCII вертикальная табуляция |
\ooo | Символ с восьмеричным значением |
\xHH | Символ с шестнадцатеричным значением. |
Вот простой пример использования escape-последовательности.
Мы можем игнорировать управляющую последовательность из заданной строки, используя необработанную строку. Для этого перед строкой нужно написать r или R . Рассмотрим следующий пример.
Метод format() в python
Метод format() является наиболее гибким и полезным методом форматирования строк. Фигурные скобки <> используются в качестве заполнителя строки и заменяются аргументом метода format() . Рассмотрим приведенный пример:
Форматирование строк в Python с помощью оператора %
Python позволяет нам использовать спецификаторы формата, используемые в операторе printf языка Си . Спецификаторы формата в Python обрабатываются так же, как и в C. Однако Python предоставляет дополнительный оператор % , который используется в качестве интерфейса между спецификаторами формата и их значениями. Другими словами, можно сказать, что он связывает спецификаторы формата со значениями.
Рассмотрим следующий пример.
Строковые функции в Python
Python предоставляет различные встроенные функции, которые используются для работы со строками.
Строка — это тип данных, предназначенный для работы с текстом. Чтобы создать строку в Python, нужно использовать одинарные или двойные кавычки. Для многострочных строк можно использовать тройные кавычки (тоже одинарные или двойные).
Было бы довольно скучно, если все строки в программе можно было бы создавать только в исходном коде. К счастью, в Python есть такая функция, как input. С ее помощью можно получить строку от пользователя.
Теория и практические задачи для закрепления на Python для начинающих. Быстрая проверка, подсказки к ошибкам на русском языке. От простого к сложному. Работает без установки в любом современном браузере.
Строки могут быть пустыми, то есть не иметь внутри себя ни одного символа. Пробел — это такой же символ, как и все остальные и эти две строки не равны.
Для того, чтобы получить длину строки, нужно использовать встроенную в Python функцию len. Эта программа, например, выведет на экран длину текста, который введет пользователь
Читайте также: