Как проверить регистр буквы python
Рассмотрим основные методы строк, которые мы можем применить в приложениях:
- isalpha() : возвращает True, если строка состоит только из алфавитных символов
- islower() : возвращает True, если строка состоит только из символов в нижнем регистре
- isupper() : возвращает True, если все символы строки в верхнем регистре
- isdigit() : возвращает True, если все символы строки — цифры
- isnumeric() : возвращает True, если строка представляет собой число
- startswith(str) : возвращает True, если строка начинается с подстроки str
- endswith(str) : возвращает True, если строка заканчивается на подстроку str
- lower() : переводит строку в нижний регистр
- upper() : переводит строку в вехний регистр
- title() : начальные символы всех слов в строке переводятся в верхний регистр
- capitalize() : переводит в верхний регистр первую букву только самого первого слова строки
- lstrip() : удаляет начальные пробелы из строки
- rstrip() : удаляет конечные пробелы из строки
- strip() : удаляет начальные и конечные пробелы из строки
- ljust(width) : если длина строки меньше параметра width, то справа от строки добавляются пробелы, чтобы дополнить значение width, а сама строка выравнивается по левому краю
- rjust(width) : если длина строки меньше параметра width, то слева от строки добавляются пробелы, чтобы дополнить значение width, а сама строка выравнивается по правому краю
- center(width) : если длина строки меньше параметра width, то слева и справа от строки равномерно добавляются пробелы, чтобы дополнить значение width, а сама строка выравнивается по центру
- find(str[, start [, end]) : возвращает индекс подстроки в строке. Если подстрока не найдена, возвращается число -1
- replace(old, new[, num]) : заменяет в строке одну подстроку на другую
- split([delimeter[, num]]) : разбивает строку на подстроки в зависимости от разделителя
- partition(delimeter) : разбивает строку по разделителю на три подстроки и возвращает кортеж из трех элементов — подстрока до разделителя, разделитель и подстрока после разделителя
- join(strs) : объединяет строки в одну строку, вставляя между ними определенный разделитель
Например, если мы ожидаем ввод с клавиатуры числа, то перед преобразованием введенной строки в число можно проверить, с помощью метода isnumeric() введено ли в действительности число, и если так, то выполнить операцию преобразования:
string = input("Введите число: ") if string.isnumeric(): number = int(string) print(number)
Проверка, начинается или оканчивается строка на определенную подстроку:
file_name = "hello.py" starts_with_hello = file_name.startswith("hello") # True ends_with_exe = file_name.endswith("exe") # False
Удаление пробелов в начале и в конце строки:
string = " hello world! " string = string.strip() print(string) # hello world!
Дополнение строки пробелами и выравнивание:
print("iPhone 7:", "52000".rjust(10)) print("Huawei P10:", "36000".rjust(10))
iPhone 7: 52000 Huawei P10: 36000
Поиск в строке
Для поиска подстроки в строке в Python применяется метод find() , который возвращает индекс первого вхождения подстроки в строку и имеет три формы:
- find(str) : поиск подстроки str ведется с начала строки до ее конца
- find(str, start) : параметр start задает начальный индекс, с которого будет производиться поиск
- find(str, start, end) : параметр end задает конечный индекс, до которого будет идти поиск
Если подстрока не найдена, метод возвращает -1:
welcome = "Hello world! Goodbye world!" index = welcome.find("wor") print(index) # 6 # поиск с 10-го индекса index = welcome.find("wor",10) print(index) # 21 # поиск с 10 по 15 индекс index = welcome.find("wor",10,15) print(index) # -1
Замена в строке
Для замены в строке одной подстроки на другую применяется метод replace() :
- replace(old, new) : заменяет подстроку old на new
- replace(old, new, num) : параметр num указывает, сколько вхождений подстроки old надо заменить на new. По умолчанию num равно -1, что соответствует первой версии метода и приводит к замене всех вхождений.
phone = "+1-234-567-89-10" # замена дефисов на пробел edited_phone = phone.replace("-", " ") print(edited_phone) # +1 234 567 89 10 # удаление дефисов edited_phone = phone.replace("-", "") print(edited_phone) # +12345678910 # замена только первого дефиса edited_phone = phone.replace("-", "", 1) print(edited_phone) # +1234-567-89-10
Разделение на подстроки
Метод split() разбивает строку на список подстрок в зависимости от разделителя. В качестве разделителя может выступать любой символ или последовательность символов. Данный метод имеет следующие формы:
- split() : в качестве разделителя используется пробел
- split(delimeter) : в качестве разделителя используется delimeter
- split(delimeter, num) : параметр num указывает, сколько вхождений delimeter используется для разделения. Оставшаяся часть строки добавляется в список без разделения на подстроки
text = "Это был огромный, в два обхвата дуб, с обломанными ветвями и с обломанной корой" # разделение по пробелам splitted_text = text.split() print(splitted_text) print(splitted_text[6]) # дуб, # разбиение по запятым splitted_text = text.split(",") print(splitted_text) print(splitted_text[1]) # в два обхвата дуб # разбиение по первым пяти пробелам splitted_text = text.split(" ", 5) print(splitted_text) print(splitted_text[5]) # обхвата дуб, с обломанными ветвями и с обломанной корой
Еще один метод — partition() разбивает строку по разделителю на три подстроки и возвращает кортеж из трех элементов — подстрока до разделителя, разделитель и подстрока после разделителя:
text = "Это был огромный, в два обхвата дуб, с обломанными ветвями и с обломанной корой" text_parts = text.partition("дуб") print(text_parts) # ('Это был огромный, в два обхвата ', 'дуб', ', с обломанными ветвями и с обломанной корой')
Если разделитель с строке не найден, то возвращается кортеж с одной строкой.
Соединение строк
При рассмотрении простейших операций со строками было показано, как объединять строки с помощью операции сложения. Другую возможность для соединения строк представляет метод join() : он объединяет список строк. Причем текущая строка, у которой вызывается данный метод, используется в качестве разделителя:
words = ["Let", "me", "speak", "from", "my", "heart", "in", "English"] # разделитель - пробел sentence = " ".join(words) print(sentence) # Let me speak from my heart in English # разделитель - вертикальная черта sentence = " | ".join(words) print(sentence) # Let | me | speak | from | my | heart | in | English
Вместо списка в метод join можно передать простую строку, тогда разделитель будет вставляться между символами этой строки:
word = "hello" joined_word = "|".join(word) print(joined_word) # h|e|l|l|o
Метод str.isupper() в Python, проверяет строку на верхний регистр
Проверяет, что все символы строки находятся в верхнем регистре
Синтаксис:
str.isupper()
Параметры:
Возвращаемое значение:
- bool , True — если все слова имеют верхний регистр символов
Описание:
Метод str.isupper() возвращает True , если все символы в строке str прописные (имеют верхний регистр), при этом строка не должна быть пустой, то есть должна иметь хотя бы один символ в верхнем регистре и не состоять из одних пробелов.
Метод str.isupper() во всех других случаях возвращает False .
Строка состоящая из символов не имеющих возможности приведение к верхнему регистру также будет возвращать False .
Например выражение ‘379’.isupper() возвращает False .
Для приведения символов строки к верхнему регистру используйте метод str.upper() .
Примеры проверки строки на верхний регистр.
>>> ''.isupper() # False >>> 'а'.isupper() # False >>> 'А'.isupper() # True >>> '20'.isupper() # False >>> 'Это 20'.isupper() # False >>> 'ЭТО 20'.isupper() # True >>> 'ВСЕ СИМВОЛЫ в СТРОКЕ ПРОПИСНЫЕ (ИМЕЮТ ВЕРХНИЙ РЕГИСТР)'.isupper() # False >>> 'ВСЕ СИМВОЛЫ В СТРОКЕ ПРОПИСНЫЕ (ИМЕЮТ ВЕРХНИЙ РЕГИСТР)'.isupper() # True
- ОБЗОРНАЯ СТРАНИЦА РАЗДЕЛА
- Метод str.capitalize(), первая буква в строке заглавная
- Метод str.casefold(), сворачивает регистр строки
- Метод str.center(), выравнивает строку по центру
- Метод str.count(), считает совпадения в строке
- Метод str.encode(), преобразует строку в байты
- Метод str.endswith(), совпадение с концом строки
- Метод str.expandtabs(), меняет табуляцию на пробел
- Метод str.find(), индекс первого совпадения в строке
- Метод str.format(), форматирует строку
- Метод str.format_map()
- Метод str.index(), индекс первого совпадения подстроки
- Метод str.isalnum(), строка состоит из цифр и букв
- Метод str.isalpha(), строка состоит только из букв
- Метод str.isascii(), все символы в строке являются ASCII
- Метод str.isdecimal(), проверяет строку на десятичное число
- Метод str.isdigit(), строка состоит только из цифр
- Метод str.isidentifier() проверяет строку на идентификатор Python
- Метод str.islower( ), проверяет строку на нижний регистр
- Метод str.isnumeric(), проверяет строку на числовые символы
- Метод str.isprintable(), проверяет на доступность для печати
- Метод str.isspace(), является ли строка пробелом
- Метод str.istitle(), проверяет наличие заглавных букв в словах
- Метод str.isupper(), проверяет строку на верхний регистр
- Метод str.join(), объединяет список строк
- Метод str.ljust(), ровняет строку по левому краю
- Метод str.lower(), строку в нижний регистр
- Метод str.lstrip(), обрезает символы в начале строки
- Метод str.maketrans(), таблица символов для str.translate()
- Метод str.partition(), делит строку по первому совпадению
- Метод str.removeprefix(), удаляет префикс строки
- Метод str.removesuffix(), удаляет суффикс строки
- Метод str.replace(), меняет подстроку/символ в строке
- Метод str.rfind(), индекс последнего совпадения подстроки
- Метод str.rindex(), индекс последнего совпадения в строке
- Метод str.rjust(), ровняет строку по правому краю
- Метод str.rpartition(), делит строку по последнему совпадению
- Метод str.rsplit(), делит строку справа
- Метод str.rstrip(), обрезает символы на конце строки
- Метод str.split(), делит строку по подстроке
- Метод str.splitlines(), делит текст по символу ‘\n’
- Метод str.startswith(), совпадение с началом строки
- Метод str.strip(), обрежет строку с обоих концов
- Метод str.swapcase(), сменит регистр символов в строке
- Метод str.title(), каждое слово с заглавной буквы
- Метод str.translate(), транслирование строки
- Метод str.upper(), переведет строку в верхний регистр
- Метод str.zfill(), дополнит строку нулями
- Форматирование строк в стиле printf
- F-string. Форматированные строки
Как проверить регистр буквы python
![]()
Методы islower() и isupper() в Python: Проверка регистра символов в строке
10 июня 2023
Оценки статьи
Еще никто не оценил статью
Строки являются одним из основных типов данных в Python, и часто возникает необходимость проверить регистр символов в строке. Для этой цели в Python предоставляются методы islower() и isupper() . В этой статье мы рассмотрим эти методы подробнее и предоставим примеры их использования.
Метод islower()
Метод islower() используется для проверки, содержит ли строка только символы в нижнем регистре. Если все символы в строке являются буквами нижнего регистра, метод вернет значение True , в противном случае — False .
Синтаксис islower()
string.islower()
Примеры использования islower()
# Пример 1 str1 = "hello" print(str1.islower()) # True # Пример 2 str2 = "Hello" print(str2.islower()) # False # Пример 3 str3 = "123abc" print(str3.islower()) # True # Пример 4 str4 = "123ABC" print(str4.islower()) # False
Метод isupper()
Метод isupper() используется для проверки, содержит ли строка только символы в верхнем регистре. Если все символы в строке являются буквами верхнего регистра, метод вернет значение True , в противном случае — False .
Синтаксис isupper()
string.isupper()
Примеры использования isupper()
# Пример 1 str1 = "HELLO" print(str1.isupper()) # True # Пример 2 str2 = "Hello" print(str2.isupper()) # False # Пример 3 str3 = "123ABC" print(str3.isupper()) # True # Пример 4 str4 = "123abc" print(str4.isupper()) # False
Заключение
Методы islower() и isupper() предоставляют удобный способ проверить, содержит ли строка символы только в нижнем или верхнем регистре соответственно. Они могут быть полезными при валидации ввода пользователей, фильтрации или обработке строк. Пользуйтесь этими методами для эффективной работы с регистром символов в строках в Python.
Определить символ в регистре

Написать программу, которая определяет в каком регистре написан символ строки в указанной позиции. Если в верхнем регистре выводится – true, если в нижнем – false.
Помогите пожалуйста на питоне
Спасибо))
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
Ответы с готовыми решениями:

Строка: Получить копию заданной строки, в котором первый символ каждого предложения написан в верхнем регистре
Напишите программу, принимающую строковое значение и возвращающую его копию, в котором первый.

Как определить, в каком регистре находится символ? (Elixir)
я не могу найти информацию как определить в каком регистре находится символ?
Если символ является буквой в верхнем регистре, то заменить предыдущий символ на пробел
ввести массив символов из N элементов. Если символ является буквой в верхнем регистре, то заменить.

Если символ является буквой в верхнем регистре, то заменить предыдущий символ на пробел
Не могу понять как сделать так что бы вводилась замена буквы на пробел //.
![]()
7908 / 4194 / 1808
Регистрация: 27.03.2020
Сообщений: 7,013
Innokenty_,
1 2 3
st = input() k = int(input()) print(st[k] == st[k].upper())
1728 / 968 / 199
Регистрация: 22.02.2018
Сообщений: 2,694
Записей в блоге: 6
Innokenty_, Или можно используя функцию ord() посмотреть в каких числовых диапазонах находятся символы нижнего и верхнего регистров. И потом просто с помощью этой функции смотреть, какому диапазону принадлежит числовое представление символа.
Хотя вариант Gdez, проще.
814 / 526 / 214
Регистрация: 22.12.2017
Сообщений: 1,495
print(input()[int(input())-1].isupper())
Регистрация: 28.03.2021
Сообщений: 5
1 2 3
str = input() n = int(input()) print(st[n - 1].isupper())
P. S. Работает не только с латинским алфавитом, но и со всеми другими алфавитами, которые включены в стандарт Unicode (русский в том числе).
Am I evil? Yes, I am!
![]()
![]()
17052 / 9999 / 2763
Регистрация: 21.10.2017
Сообщений: 21,957
Сообщение от Mvbalakirev 
Работает не только с латинским алфавитом, но и со всеми другими алфавитами, которые включены в стандарт Unicode
а все остальные вышеприведенные коды, что, не работают?
Добавлено через 33 секунды
И чем твой код отличается от кода постом выше?
1728 / 968 / 199
Регистрация: 22.02.2018
Сообщений: 2,694
Записей в блоге: 6
Innokenty_, На самом деле условие задано не корректно. Так как понятие «символ» подразумевает не только буквы но и специальные символы. А понятие регистра относится только к буквам. Поэтому в условии или должны были указать, что в строке только буквы, или предусмотреть сообщение на случай, когда символ не буква.
Причем интересно,
вариант Gdez, на все специальные символы выдает True,
а вариант codcw, на все специальные символы выдает False.
Добавлено через 3 минуты
Код Mvbalakirev, так же на все специальные символы выдает False.
Добавлено через 3 минуты
Мне лень писать предложенный мной вариант, но в нем можно выдавать True или False только когда символ буква, а когда специальный символ, выдавать None или сообщение «символ не зависит от регистра».
Добавлено через 1 минуту
Извините, просто я формалист.
Добавлено через 43 минуты
Mvbalakirev, Вы проверяли в других алфавитах? Я проверил в греческом. Только вариант Gdez, дает правильный ответ, а Ваш и вариант codcw, в греческом алфавите дают не правильный ответ.
Вот здесь все три варианта:
1 2 3 4 5 6 7 8 9
st = input() k = int(input()) print(st[k] == st[k].upper()) print(input()[int(input())-1].isupper()) str = input() n = int(input()) print(st[n - 1].isupper())
Вывод для прописной «альфа»
1 2 3 4 5 6 7 8 9
abΑc 2 True abΑc 2 False abΑc 2 False