Форум программистов, компьютерный форум, киберфорум
Java
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 20.02.2024
Сообщений: 25

JAVA шаблон и превращение в регулярное выражение

04.03.2024, 15:29. Показов 1074. Ответов 1
Метки java (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет!
Я начал изучать Java как основной язык програмирования, но запнулся на шаблонах Java.
Есть шаблон (?)[##] и нужно его представить в виде регулярного выражения. Как я понял этот шаблон ищёт в строке любой символ за которым идёт две цыфры.
В книге был пример - ?##*a(альфа) и там регулярное выражение выводилось \\S\\d\\d\\S*[a-z]. Я попытался переделать под свой шаблон вышло \\S\\d\\d, но не уверен что правильно.
Кто может помочь решить данную задачу.
Код самой програмы:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
package ua.i.tsymbala;
import java.util.Arrays;
import java.util.Random;
import java.util.Scanner;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
 
public class project3 implements TextProcessor {
 
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        project3 textProccesor2 = new project3();
        String s2 = scan.nextLine();
        System.out.println("шаблон " + textProccesor2.getTemplate());
        System.out.println("регулярное выражение " + textProccesor2.getRegex());
        System.out.println("масив примеров слов " + Arrays.toString(textProccesor2.get10Examples()));
        System.out.println("Количество входов шаблона у строку = " + textProccesor2.regexCount(s2));
        System.out.println("Удаление слова, которое удовлетворяет шаблон " + textProccesor2.regexRemove(s2));
        System.out.println("Замена слова, которое удовлетворяет шаблон " + textProccesor2.regexReplace(s2));
        System.out.println("масив слов,за шаблоном " + Arrays.toString(textProccesor2.regexFind(s2)));
    }
 
 
    public String process(String inputSequence) {
        String[] tokens = inputSequence.split("\\s+");
        double result = Double.parseDouble(tokens[1]);
 
        for (int i = 2; i < tokens.length; i++) {
            switch (tokens[0]) {
                case "+":
                    result += Double.parseDouble(tokens[i]);
                    break;
                case "-":
                    result -= Double.parseDouble(tokens[i]);
                    break;
                case "*":
                    result *= Double.parseDouble(tokens[i]);
                    break;
                default:
                    // handle unsupported operation
                    break;
            }
        }
 
        return String.valueOf(result);
    }
    @Override
    public int regexCount(String inputSequence) {   //(?)[##]
        int n = 0;
        Pattern p = Pattern.compile("\\S\\d\\d");
        Matcher m = p.matcher(inputSequence);
        while (m.find()) {
            n++;     } //     System.out.print(m.group() + " ");
        return n;  }
    @Override
    public String regexRemove (String inputSequence) {
        Pattern p = Pattern.compile("\\S\\d\\d");
        Matcher m = p.matcher(inputSequence);
        String s = m.replaceAll("");
        return s;   }
    @Override
    public String regexReplace (String inputSequence) {
        Pattern p = Pattern.compile("\\S\\d\\d");
        Matcher m = p.matcher(inputSequence);
        String s = m.replaceAll("*****");
        return s;   }
    @Override
    public String[] regexFind(String inputSequence) {
        int i=0;
        String[] massiv = new String[regexCount(inputSequence)];
        Pattern p = Pattern.compile("\\S\\d\\d");
        Matcher m = p.matcher(inputSequence);
        while (m.find()) {
            massiv[i]=m.group();
            i++;    }
        return massiv;  }
    @Override
    public String getTemplate() {
        String s = "(?)[##]";//(?)[##] ;
        return s;  }
    @Override
    public String getRegex() {
        String s = "\\S\\d\\d";//(?)[##] ;
        return s;  }
    @Override
    public String[] get10Examples() {
        char ch1, ch2, ch3, ch4;
        int g;
        String frag;
        String[] s = new String[10];
        Random r = new Random();
        StringBuilder slovo;
        for (int i=0; i<10; i++) {
            frag = "";
            slovo = new StringBuilder();
            g = r.nextInt(9);
            ch1 = (char) (r.nextInt(100)+32);
            ch2 = (char) (r.nextInt(9) + 48);
            ch3 = (char) (r.nextInt(9) + 48);
            for (int m=0; m<=g; m++) {
                frag = frag + ((char) (r.nextInt(100)+32));    }
            ch4= (char) (r.nextInt(26) + 97);
            slovo.append(ch1).append(ch2).append(ch3).append(frag).append(ch4);
            s[i] = slovo.toString();  }
        return s;   }
}
 
interface TextProcessor {
    String process(String inputSequence);
    int regexCount(String inputSequence);
    String regexRemove(String inputSequence);
    String regexReplace(String inputSequence);
    String[] regexFind(String inputSequence);
    String getTemplate();
    String getRegex();
    String[] get10Examples();
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.03.2024, 15:29
Ответы с готовыми решениями:

Регулярное выражение шаблон
привет. вопрос возможноли сделать исключения из шаблона? строка: sadsdsads4444rerere5555asdsadsada нужно: 44445555 как исключть:...

Регулярное выражение JAVA
Добрый день у меня есть регулярное выражение типа Pattern.compile(&quot;^{1}+$&quot;);. Оно ищет совпадение по первому слову. То есть что бы у...

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

1
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
09.03.2024, 17:41
Лучший ответ Сообщение было отмечено olegih1 как решение

Решение

Цитата Сообщение от olegih1 Посмотреть сообщение
любой символ за которым идёт две цыфры
Цитата Сообщение от olegih1 Посмотреть сообщение
\\S\\d\\d, но не уверен что правильно
правильно

Добавлено через 33 секунды
Цитата Сообщение от olegih1 Посмотреть сообщение
любой символ
Любой НЕ ПРОБЕЛЬНЫЙ символ
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
09.03.2024, 17:41
Помогаю со студенческими работами здесь

Java regex - регулярное выражение
Доброго времени суток, столкнулся с регулярными выражениями в задании, и ... застопорился, со вчерашнего вечера не дает мне покоя, решение...

Есть ли в Java Регулярное выражение как в Perl?
На Перл это так: s/(*?)(*)+\2/$1$2/; А на Джава я что-то даже не нашёл ничего подобного. Есть такое? В частности: $1 $2 ...

Есть ли регулярное выражение в Java для ограничения количества символов?
Пример. Может вводиться только число не больше чем 6 символов. Есть ли регулярное выражение для того, чтобы это проверялось и в случае...

Регулярное выражение под шаблон: "От 10 до 60 символов, от а до я, 2 пробела, слова с большой буквы"
от 10 до 60 символов от а до я 2 пробела слова с большой буквы пример: &quot;Три Три Три&quot; Я сделал так, но это шлак... ...

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


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru