Как проверить есть ли в строке буква java

Содержание
  1. Проверка строки на наличие пробелов, символов и букв
  2. Решение
  3. Решение
  4. 6 ответов
  5. вот регулярное выражение для вас
  6. экстренное regex для вашей справки:
  7. Как проверить есть ли в строке буква java
  8. Извлечение символов и подстрок
  9. Сравнение строк
  10. Поиск в строке
  11. Замена в строке
  12. Обрезка строки
  13. Изменение регистра
  14. Split
  15. Строки в Java, методы класса String
  16. Объединение строк
  17. Извлечение символов и подстрок
  18. Сравнение строк
  19. Поиск в строке
  20. Замена в строке
  21. Обрезка строк
  22. Изменение регистра
  23. Разбиение строки на подстроки
  24. Видео по теме
  25. Как проверить есть ли в строке буква java
  26. Создание строк
  27. Конкатенация или слияние строк в Java
  28. Наиболее употребительные методы класса String
  29. Еще раз конкатенация
  30. Определение количества символов в строке
  31. Извлечение символов из строки
  32. Извлечение подстроки из строки
  33. Разбиение строк
  34. Поиск в строке
  35. Модификация строк
  36. Сравнение строк

Проверка строки на наличие пробелов, символов и букв

Добрый день. Нужно проверить строку на наличие пробелов, символов и букв, если такие имеются, то вывести сообщение об ошибке. Пока мне только удалось сделать проверку через условие с string.matches

tickПроверка строки на наличие определенных символов, слов
Подскажите, пожалуйста, как проверить строку на то, что: 1) состоит только из пробелов(любого.

tickПроверка строки на наличие определённой комбинации символов
Здравствуйте. Нужно написать программу для перевода температуры в разные единицы измерения.

tickПроверка на наличие букв
Приветствую! Имеется переменная text. Как проверить, содержатся ли в этой переменной буквы.

Доля цифровых символов и доля пробелов в общем количестве символов заданной строки
Друзья,товарищи,сограждане,братья и сестры,помогите с лабой по Java.Пользователь вводит.

Из условия выходит, что в строке допускаются только цифры, а значит:

Решение

если до завтра никто не отпишет то я попробую сделать, а сейчас уже поздно, пора домой

Решение

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Считывание строки, сравнение её символов на наличие цифр и вывод
Пользователь вводит строку символов. Программа должна вычленить из этой строки все цифры и.

Проверка строки на наличие букв и символов
Добрый вечер! Как в android проверить editText на наличие букв и символов? Мне нужно, что бы.

tickСтроки. Из строки символов удалить символы, отличных от русских букв и пробелов
Задана строка из произвольного количества слов, разделенных пробелами. Из заданной строки символов.

tickПроверка строки на наличие символов
Написал функцию для проверки строки, если в ней есть любые символы, мешающие преобразовать ее в.

Источник

Мне нужно регулярное выражение, которое будет удовлетворять обоим условиям.

он должен дать мне true только тогда, когда строка содержит как A-Z, так и 0-9.

вот что я пробовал:

6 ответов

Я подозреваю, что регулярное выражение ниже замедляется осмотром, но оно должно работать независимо:

регулярное выражение утверждает, что нет заглавной буквы (?=.*[A-Z]) где-то в строке, и утверждает, что есть цифры (?=.*2) где-то в строке, а затем проверяет, все ли это алфавитный символ или цифра.

его легче писать и читать, если вы используете два отдельных регулярных выражений:

еще лучше, напишите метод:

буква может быть до или после цифры, поэтому это выражение должно работать:

вот пример кода, который использует это выражение:

Это должно решить вашу проблему:

но это нечитабельно. Я бы предложил сначала проверить вход с «^[а-З0-9]+$», а затем проверить с «[А-я]», чтобы убедиться, что он содержит по крайней мере одно письмо, потом проверить на «7», чтобы убедиться, что он содержит по крайней мере одну цифру. Таким образом, вы можете легко добавлять новые ограничения, и код останется читаемым.

вот регулярное выражение для вас

основные:

матч 0 или любое количество любых символов: *

сопоставьте любой символ в наборе (диапазоне) символов: [start-end]

сопоставьте одно из регулярных выражений из группы: (regex1|regex2|regex3)

Проверьте строку против regex

просто позвоните yourString.matches(theRegexAsString)

проверьте, содержит ли строка буквы:

проверьте, есть ли письмо: yourString.matches(«.*[a-zA-Z].*»)

проверьте, есть ли буква в нижнем регистре: yourString.matches(«.*[a-z].*»)

проверьте, есть ли верхний корпус письмо: yourString.matches(«.*[A-Z].*»)

проверьте, содержит ли строка числа:

проверьте, содержит ли строка число и букву:

самый простой способ-дважды сопоставить буквы и цифры

если вы предпочитаете сопоставлять все вместе, регулярное выражение будет чем-то вроде: сопоставьте строку, которая где-то имеет символ, а затем номер в любом положении, или наоборот. Таким образом, ваше регулярное выражение будет:

экстренное regex для вашей справки:

проверьте, если строка звезды с буквой

Проверьте, заканчивается ли строка номером

Источник

Как проверить есть ли в строке буква java

Для соединения строк можно использовать операцию сложения («+»):

При этом если в операции сложения строк используется нестроковый объект, например, число, то этот объект преобразуется к строке:

Фактически же при сложении строк с нестроковыми объектами будет вызываться метод valueOf() класса String. Данный метод имеет множество перегрузок и преобразует практически все типы данных к строке. Для преобразования объектов различных классов метод valueOf вызывает метод toString() этих классов.

Другой способ объединения строк представляет метод concat() :

Метод concat() принимает строку, с которой надо объединить вызывающую строку, и возвращает соединенную строку.

Извлечение символов и подстрок

Как и в массивах индексация начинается с нуля.

srcBegin : индекс в строке, с которого начинается извлечение символов

srcEnd : индекс в строке, до которого идет извлечение символов

dst : массив символов, в который будут извлекаться символы

dstBegin : индекс в массиве dst, с которого надо добавлять извлеченные из строки символы

Сравнение строк

Для сравнения строк используются методы equals() (с учетом регистра) и equalsIgnoreCase() (без учета регистра). Оба метода в качестве параметра принимают строку, с которой надо сравнить:

Читайте также:  Как забить табак в кальян чтобы было много дыма

Еще один специальный метод regionMatches() сравнивает отдельные подстроки в рамках двух строк. Он имеет следующие формы:

Метод принимает следующие параметры:

toffset : начальный индекс в вызывающей строке, с которого начнется сравнение

other : строка, с которой сравнивается вызывающая

oofset : начальный индекс в сравниваемой строке, с которого начнется сравнение

len : количество сравниваемых символов в обеих строках

И еще одна пара методов int compareTo(String str) и int compareToIgnoreCase(String str) также позволяют сравнить две строки, но при этом они также позволяют узнать больше ли одна строка, чем другая или нет. Если возвращаемое значение больше 0, то первая строка больше второй, если меньше нуля, то, наоборот, вторая больше первой. Если строки равны, то возвращается 0.

Для определения больше или меньше одна строка, чем другая, используется лексикографический порядок. То есть, например, строка «A» меньше, чем строка «B», так как символ ‘A’ в алфавите стоит перед символом ‘B’. Если первые символы строк равны, то в расчет берутся следующие символы. Например:

Поиск в строке

Метод startsWith() позволяют определить начинается ли строка с определенной подстроки, а метод endsWith() позволяет определить заканчивается строка на определенную подстроку:

Замена в строке

Метод replace() позволяет заменить в строке одну последовательность символов на другую:

Обрезка строки

Метод trim() позволяет удалить начальные и конечные пробелы:

Метод substring() возвращает подстроку, начиная с определенного индекса до конца или до определенного индекса:

Изменение регистра

Split

В данном случае строка будет разделяться по пробелу. Консольный вывод:

Источник

Строки в Java, методы класса String

Для работы со строками в Java существует класс String. И для объявления новой строки можно использовать один из способов:

В последнем варианте 3 – это начальный индекс (индексы считаются с нуля), а 4 – это кол-во символов. То есть, строка str4 содержит строку «come».

Важной особенностью строк в Java является их неизменяемость. Это значит, что в строке нельзя попросту изменить какой-либо символ и получить другую строку. Все строки создаются и существуют в неизменном виде, пока не будут уничтожены (как правило, автоматически сборщиком мусора). А переменные str1, str2, str3 и str4 следует воспринимать лишь как ссылки на эти строки. То есть, в любой момент в программе можно записать такую конструкцию:

что означает изменение ссылки str1 на строку «hello», на которую указывает ссылка str3. Соответственно, если на первую строку «Java» не будет указывать никакая ссылка, то она автоматически уничтожается.

У класса String есть несколько полезных методов:

Название метода класса String

возвращает число символов в строке (длину строки)

возвращает строку в виде массива символов char[]

определяет является ли строка пустой

преобразует объект в строковый вид

сравнивает две строки

возвращает символ строки по индексу

возвращает группу символов

сравнивает строки с учетом регистра

сравнивает строки без учета регистра

сравнивает подстроки в строках

находит индекс первого вхождения подстроки в строку

находит индекс последнего вхождения подстроки в строку

определяет, начинается ли строка с подстроки

определяет, заканчивается ли строка на определенную подстроку

заменяет в строке одну подстроку на другую

удаляет начальные и конечные пробелы

возвращает подстроку, начиная с определенного индекса до конца или до определенного индекса

переводит все символы строки в нижний регистр

переводит все символы строки в верхний регистр

Разберем работу часто используемых методов класса String. Первый метод, как написано, возвращает длину строки. Например, если нам дана вот такая строка

то метод length() вернет значение 4

Далее, если к строке str2

применить метод toCharArray():

то получим массив символов с содержимым этой строки. Следующий пример. У нас есть пустая строка

тогда мы можем определить это, например, так:

Но, если строка задана вот так:

то это означает, что ссылка s не указывает ни на какой класс String и, соответственно, мы не можем вызывать методы этого класса. В этом случае проверку следует делать так:

мы здесь сначала проверяем: указывает ли ссылка s на объект класса и если это так, то только потом будет идти обращение к методу length().

Объединение строк

Для соединения строк можно использовать операцию сложения («+»):

При этом если в операции сложения строк используется не строковый объект, например, число, то этот объект преобразуется к строке:

будут сливаться в одно слово «HelloJava», если их объединить с помощью оператора +:

но если мы хотим, чтобы две подстроки при соединении были разделены пробелом, то можно воспользоваться методом join() следующим образом:

В общем случае вместо пробела здесь можно ставить любой разделитель в виде строки.

Обратите внимание, что каждый раз при объединении строк мы получали новую строку как результат объединения.

Извлечение символов и подстрок

Для извлечения символов по индексу в классе String определен метод

char charAt(int index)

Он принимает индекс, по которому надо получить символов, и возвращает извлеченный символ:

(здесь как и в массивах первый индекс равен 0).

Если надо извлечь сразу группу символов или подстроку, то можно использовать метод

getChars(int srcBegin, int srcEnd, char[] dst, int dstBegin)

Сравнение строк

Для простого сравнения строк используются методы equals() (с учетом регистра) и equalsIgnoreCase() (без учета регистра). Оба метода в качестве параметра принимают строку, с которой сравниваются:

Обратите внимание, что в отличие сравнения числовых и других данных примитивных типов для сравнения строк не рекомендуется использовать оператор ==. То есть, записывать вот такое сравнение лучше не использовать:

(хотя, оно тоже будет работать). Вместо этого следует использовать метод equals() класса String.

Другая пара методов:

int compareTo(String str) и int compareToIgnoreCase(String str)

также сравнивают строки между собой, но в отличие от equals() они еще позволяют узнать больше ли одна строка другой или нет. Если возвращаемое значение этих методов больше 0, то первая строка больше второй, если меньше нуля, то, наоборот, вторая больше первой. Если строки равны, то возвращается 0.

Для определения больше или меньше одна строка, чем другая, используется лексикографический порядок. То есть, например, строка «A» меньше, чем строка «B», так как символ ‘A’ в алфавите стоит перед символом ‘B’. Если первые символы строк равны, то в расчет берутся следующие символы. Например:

Еще один специальный метод

сравнивает отдельные подстроки в пределах двух строк. Он имеет такие реализации:

Например, ниже в строке str1 сравнивается подстрока wor с подстрокой wor строки str2:

Поиск в строке

Метод startsWith() позволяют определить начинается ли строка с определенной подстроки, а метод endsWith() позволяет определить заканчивается строка на определенную подстроку:

Замена в строке

Метод replace() позволяет заменить в строке одну последовательность символов на другую:

Обрезка строк

Метод trim() позволяет удалить начальные и конечные пробелы:

Метод substring() возвращает подстроку, начиная с определенного индекса до конца или до определенного индекса:

Изменение регистра

Разбиение строки на подстроки

Метод split() позволяет разбить строку на подстроки по определенному разделителю. Разделитель – это какой-нибудь символ или набор символов (передается в качестве параметра). Например, разобьем текст на отдельные слова (учитывая, что слова разделены пробелом):

Видео по теме

default

#1 Установка пакетов и первый запуск программы

default

#2 Структура программы, переменные, константы, оператор присваивания

default

#3 Консольный ввод/вывод, импорт пакетов

default

#4 Арифметические операции

default

#5 Условные операторы if и switch

default

#6 Операторы циклов while, for, do while

default

#7 Массивы, обработка элементов массива

default

#8 (часть 1) Строки в Java, методы класса String

default

default

#9 Битовые операции И, ИЛИ, НЕ, XOR

default

#10 Методы, их перегрузка и рекурсия

© 2021 Частичное или полное копирование информации с данного сайта для распространения на других ресурсах, в том числе и бумажных, строго запрещено. Все тексты и изображения являются собственностью сайта

Источник

Как проверить есть ли в строке буква java

Строка — это упорядоченная последовательность символов. В Java строка является основным носителем текстовой информации. Для работы со строками здесь используются следующие классы: String, StringBuilder, StringBuffer. В этом уроке речь пойдет о классе String, его на первых порах будет вполне достаточно.

В данном уроке рассматривается:

В уроке 6 уже упоминалась работа со строками, а именно, как создавать строку. Также частично со строками мы встречались в предыдущих уроках. В этом и следующих двух уроках мы углубим знания о строках. В этом уроке будут рассмотрены создание строк в Java и наиболее популярные методы при работе со строками. Следующий урок будет посвящен форматированию строк. И еще один урок будет на тему работы с регулярными выражениями в Java, поскольку регулярные выражения достаточно мощный и нужный инструмент при работе со строками.

Но начнем с самого начала.

Создание строк

Строка в Java является объектом, поэтому ее можно создать, как и любой другой объект, при помощи оператора new.

Также строку можно создать при помощи литерала (фразы заключенной в кавычки) следующим образом.

Обе строки, независимо от способа создания являются объектами — экземплярами класса String.

Важный момент: создание объектов при помощи литерала возможно только в классе String. Объекты любого другого класса при помощи литерала создать нельзя.

Можно также создать массив строк. Например, так:

Конкатенация или слияние строк в Java

Для того, чтобы объединить несколько разных строк в одну, в Java можно использовать перегруженные (специально для объектов String) операторы «+» и «=+».

Еще один важный момент : операторы «+» и «=+», перегруженные для String, являются единственными перегруженными операторами в Java. Программист здесь не имеет возможности самостоятельно перегружать какие-либо операторы (как, например, в С++ и некоторых других языках).

Пример 1:

На консоль будет выведено «Мама мыла раму»

Пример 2:

Пример 3:

Наиболее употребительные методы класса String

При использовании IDE можно легко увидеть, какие методы есть у класса и получить подсказку по их использованию. На примере IDE Eclipse: для того, чтобы открыть список методов и быстро выбрать подходящий, нужно после имени переменной поставить точку и нажать комбинацию клавиш CTRL + Space (пробел). После этого появится окно, как на рисунке 14.1, где будут перечислены все доступные методы класса.

methods

При выборе метода из этого списка, справа (или слева) появится желтое окно с подсказкой по его использованию. При помощи нажатия Enter или двойного клика мыши метод можно вставить в ваш код, не прибегая к ручному набору.
Также после имени переменной и точки можно начать набирать вручную имя метода и после введения нескольких первых букв нажать CTRL + Space (пробел). При этом, если метод, начинающийся на эти буквы один, то он автоматически подставится в код, если методов несколько, то откроется окно, как на рисунке 14.1, где будут перечислены только те методы, которые начинаются с этих введенных вами букв.
Это было лирическое отступление о том, как облегчить себе жизнь. Далее рассмотрим методы, которые чаще всего используются при работе со строками. Некоторые задачи можно решить и без применения этих методов, но их знание значительно облегчает процесс программирования. В дальнейшем описании, первое слово, которое стоит перед названием метода — тип значения, которое возникнет в результате работы метода (значение, которое метод возвращает).

Еще раз конкатенация

String concat(String str) — производит ту же конкатенацию, что была описана выше, но использование этого метода из класса String положительно влияет на производительность и скорость программы. На небольших примерах это незаметно и не существенно, но в более серьезных приложениях стоит использовать этот метод. Результатом работы метода будет строка. Параметр, который нужно передавать в метод для конкатенации — тоже строка, о чем нам говорит значение в скобках (String str).

Перепишем пример 2, при помощи concat():

Определение количества символов в строке

Для того чтобы определить количество символов в строке, используется метод length.

int length() возвращает длину строки. Длина равна количеству символов Unicode в строке.

Пример 4:

Извлечение символов из строки

Если нам требуется узнать, какой символ находиться в строке на конкретной позиции, можем использовать метод charAt.

char charAt(int index) возвращает символ, находящийся по указанному индексу в строке. Результатом работы метода будет символ типа char. Параметр, который передается в метод — целое число. Первый символ в строке, подобно массивам, имеет индекс 0.

Пример 5: определить последний символ в строке.

Если мы хотим работать со строкой, как с массивом символов, можем конвертировать строку в массив при помощи метода toCharArray.

char[] toCharArray() — преобразует строку в новый массив символов.

Пример 6: поменять в строке символы пробела на точки при помощи преобразования в массив символов (для этой задачи есть более простое решение, нежели преобразование в массив, но об этом чуть позже).

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

Извлечение подстроки из строки

String substring(int beginIndex, int endIndex) или substring(int beginIndex) — возвращает новую строку, которая является подстрокой используемой строки. В параметрах метода нужно указать индекс строки, с которого начинается подстрока и индекс, которым заканчивается. Также возможно указывать только начальный индекс. В этом случае будет возвращена подстрока от начального индекса и до конца строки.

Пример 7.

Разбиение строк

Для разбиения строк на части используется метод String[] split(String regex), который разбивает строку на основании заданного регулярного выражения. О регулярных выражениях поговорим в одном из следующих уроков. Здесь покажем пример простого разбиения строки заданного одним символом.

Пример 8.

Поиск в строке

boolean contains(CharSequence s) — проверяет, содержит ли строка заданную последовательность символов и возвращает true или false.

Пример 9.

boolean endsWith(String suffix) — проверяет завершается ли строка определенными символами и возвращает true или false.

Пример 10.

boolean startsWith(String prefix) или startsWith(String prefix, int toffset) — проверяет, начинается ли строка с определенных символов. Во втором случае можно указать позицию с которой необходимо начать поиск префикса.

Пример 11.

Пример 12

int lastIndexOf(int ch), lastIndexOf(int ch, int fromIndex), lastIndexOf(String str), lastIndexOf(String str, int fromIndex) — аналогично предыдущему случаю, только ищется последнее вхождение символа или подстроки в строке.

Модификация строк

Модификация строк не является модификацией как таковой. Дело в том, что объекты класса String после создания уже нельзя изменять. Но можно создать копию строки с изменениями. Именно это и делают следующие методы.
toLowerCase() — преобразовать строку в нижний регистр;
toUpperCase() — преобразовать строку в верхний регистр;
trim() — отсечь на концах строки пустые символы;

String replace(char oldChar, char newChar), replace(CharSequence target, CharSequence replacement) — замена в строке одного символа или подстроки на другой символ или подстроку.

Вспомним пример 6, где нужно было поменять в строке символы пробела на точки и перепишем его с использованием replace:

Сравнение строк

boolean equals(Object anObject) — проверяет идентичность строк. Возвращает true только в том случае, если в строках представлена одинаковая последовательность символов одной величены.

Пример 14

int compareTo(String anotherString) — так же проверяет идентичность строк, однако, в отличии от метода equals возвращает:

Данный метод предназначен для упорядочивания строк. Он позволяет сравнить строки между собой и определить предшествующую строку. Для того, чтобы реализовать такое сравнение метод сравнивает числовые значения букв.

Рассмотрим пример с именами «Маша» и «Миша». При сравнении этих двух имен (пример 15), метод compareTo укажет, что имя «Маша» предшествует имени «Миша» (выдав отрицательное число) или наоборот, «Миша» следует за «Маша» (выдав положительное число). При упорядочивании имен по алфавиту мы бы упорядочили эти имена именно так. Метод в данном случае определяет, что числовое значение буквы «а» в «Маша» меньше, чем числовое значение «и» в Миша.

Пример 15

Однако, в случае, если мы напишем «маша» с маленькой буквы и попробуем сравнить с «Миша», то получим положительное число.

То есть в данном случае имя «Миша» предшествует имени «маша». Это происходит потому, что в таблице символов Юникода буквы верхнего регистра предшествуют нижнему.

Для сравнения строк без учета регистра символов используется функция int compareToIgnoreCase(String str)

Как мы видим, при сравнивании «маша» с «Миша» мы снова получаем отрицательное значение, то есть «маша» предшествует имени «Миша».

Источник

Adblock
detector