Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 11.08.2015
Сообщений: 123
07.11.2017, 13:46  [ТС]
Студворк — интернет-сервис помощи студентам
Собственно вопрос: как реализовать регулярное выражение, чтобы число с плавающей точкой было строго больше 0, и строго меньше 1. В интернете нашел пример:
C++
1
std::regex floating_point_numb("((\\+)?[[:digit:]]+)(\\.(([[:digit:]]+)?))?((e|E)((\\+|-)?)[[:digit:]]+)?");
но он для любого числа с плавающей точкой, не понимаю как поменять его для удовлетворения моих условий. Сижу документацию MSDN лопатю но не все понимаю.
0
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
07.11.2017, 14:15
C++
1
"^\\+?0*\\.0*[1-9]\\d+$"
0
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
07.11.2017, 14:48
Зачем такие сложности? Почему нельзя просто сравнить?
0
0 / 0 / 0
Регистрация: 11.08.2015
Сообщений: 123
07.11.2017, 15:08  [ТС]
Данные в текстовом формате, надо что-то типа "защиты от дураков".
0
Эксперт С++
 Аватар для hoggy
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
07.11.2017, 15:12
Цитата Сообщение от Renji Посмотреть сообщение
"^\\+?0*\\.0*[1-9]\\d+$"
оно у вас не работает (хз почему):

http://rextester.com/AYNZNF60991

C++
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
#include <iostream>
#include <regex>
 
bool matched(const char* const str)
{
    const std::regex validator("^\\+?0*\\.0*[1-9]\\d+$");
    if(std::regex_match(str, validator))
        return true;
    return false;
}
 
void test(const char* const str, const bool expect)
{
    std::cout << std::boolalpha;
    const bool real = matched(str);
    if(real==expect)
        return;
        
    std::cout << "[TEST FAILED]"
        " '" << str << "'"
        " expect " << expect 
        << std::endl; 
}
 
 
int main()
{
    test(""      , false);
    test("abc"   , false);
    test("0.abc" , false);
    test("0.0abc", false);
 
    test("0.0"   , false);
    test("1.5"   , false);
    test("1.0"   , false);
    test("0.5"   , true );
    test("0.05"  , true );
    test("0.55"  , true );
    test("0.055" , true );
    
    test("00.0"  , false);
    test("01.5"  , false);
    test("01.0"  , false);
    test("00.5"  , true );
    test("00.05" , true );
    test("00.55" , true );
    test("00.055", true );
 
    test("+0.0"  , false);
    test("+1.5"  , false);
    test("+1.0"  , false);
    test("+0.5"  , true );
    test("+0.05" , true );
    test("+0.55" , true );
    test("+0.055", true );
    
    test("+00.0"  , false);
    test("+01.5"  , false);
    test("+01.0"  , false);
    test("+00.5"  , true );
    test("+00.05" , true );
    test("+00.55" , true );
    test("+00.055", true );
}
вот так работает (хз почему)

http://rextester.com/QUG70227
C++
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
#include <iostream>
#include <regex>
 
bool matched(const char* const str)
{
    const std::regex validator("^\\+?0*\\.0*[1-9]\\d*+$");
    if(std::regex_match(str, validator))
        return true;
    return false;
}
 
void test(const char* const str, const bool expect)
{
    std::cout << std::boolalpha;
    const bool real = matched(str);
    if(real==expect)
        return;
        
    std::cout << "[TEST FAILED]"
        " '" << str << "'"
        " expect " << expect 
        << std::endl; 
}
 
 
int main()
{
    test(""      , false);
    test("abc"   , false);
    test("0.abc" , false);
    test("0.0abc", false);
 
    test("0.0"   , false);
    test("0.00"  , false);
    test("1.5"   , false);
    test("1.0"   , false);
    test("0.5"   , true );
    test("0.05"  , true );
    test("0.55"  , true );
    test("0.055" , true );
    
    test("00.0"  , false);
    test("01.5"  , false);
    test("01.0"  , false);
    test("00.5"  , true );
    test("00.05" , true );
    test("00.55" , true );
    test("00.055", true );
 
    test("+0.0"  , false);
    test("+1.5"  , false);
    test("+1.0"  , false);
    test("+0.5"  , true );
    test("+0.05" , true );
    test("+0.55" , true );
    test("+0.055", true );
    
    test("+00.0"  , false);
    test("+01.5"  , false);
    test("+01.0"  , false);
    test("+00.5"  , true );
    test("+00.05" , true );
    test("+00.55" , true );
    test("+00.055", true );
}

ещё хотелось бы понять,
почему мой вариант регулярки не взлетел:

http://rextester.com/QSOZV29106

C++
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
#include <iostream>
#include <regex>
 
bool matched(const char* const str)
{
    const std::regex validator("^\\+?0*\\.(0*[1-9]+)|([1-9]*)$");
    if(std::regex_match(str, validator))
        return true;
    return false;
}
 
void test(const char* const str, const bool expect)
{
    std::cout << std::boolalpha;
    const bool real = matched(str);
    if(real==expect)
        return;
        
    std::cout << "[TEST FAILED]"
        " '" << str << "'"
        " expect " << expect 
        << std::endl; 
}
 
int main()
{
    test(""      , false);
    test("abc"   , false);
    test("0.abc" , false);
    test("0.0abc", false);
 
    test("0.0"   , false);
    test("1.5"   , false);
    test("1.0"   , false);
    test("0.5"   , true );
    test("0.05"  , true );
    test("0.55"  , true );
    test("0.055" , true );
    
    test("00.0"  , false);
    test("01.5"  , false);
    test("01.0"  , false);
    test("00.5"  , true );
    test("00.05" , true );
    test("00.55" , true );
    test("00.055", true );
 
    test("+0.0"  , false);
    test("+1.5"  , false);
    test("+1.0"  , false);
    test("+0.5"  , true );
    test("+0.05" , true );
    test("+0.55" , true );
    test("+0.055", true );
    
    test("+00.0"  , false);
    test("+01.5"  , false);
    test("+01.0"  , false);
    test("+00.5"  , true );
    test("+00.05" , true );
    test("+00.55" , true );
    test("+00.055", true );
}
разобрался.
логическое "или" `подвыражения` аморально выбирает.

вот рабочий вариант:
http://rextester.com/NQAVC98382

C++
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
#include <iostream>
#include <regex>
 
bool matched(const char* const str)
{
    const std::regex validator("^\\+?0*\\.((0*[1-9]+)|([1-9]*))$");
    if(std::regex_match(str, validator))
        return true;
    return false;
}
 
void test(const char* const str, const bool expect)
{
    std::cout << std::boolalpha;
    const bool real = matched(str);
    if(real==expect)
        return;
        
    std::cout << "[TEST FAILED]"
        " '" << str << "'"
        " expect " << expect 
        << std::endl; 
}
 
int main()
{
    test(""      , false);
    test("abc"   , false);
    test("0.abc" , false);
    test("0.0abc", false);
 
    test("0.0"   , false);
    test("0.00"  , false);
    test("1.5"   , false);
    test("1.0"   , false);
    test("0.5"   , true );
    test("0.05"  , true );
    test("0.55"  , true );
    test("0.055" , true );
    
    test("00.0"  , false);
    test("01.5"  , false);
    test("01.0"  , false);
    test("00.5"  , true );
    test("00.05" , true );
    test("00.55" , true );
    test("00.055", true );
 
    test("+0.0"  , false);
    test("+1.5"  , false);
    test("+1.0"  , false);
    test("+0.5"  , true );
    test("+0.05" , true );
    test("+0.55" , true );
    test("+0.055", true );
    
    test("+00.0"  , false);
    test("+01.5"  , false);
    test("+01.0"  , false);
    test("+00.5"  , true );
    test("+00.05" , true );
    test("+00.55" , true );
    test("+00.055", true );
}
0
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
07.11.2017, 15:14
Цитата Сообщение от hoggy Посмотреть сообщение
оно у вас не работает (хз почему):
Ага, d+ и d* попутал.
0
0 / 0 / 0
Регистрация: 11.08.2015
Сообщений: 123
07.11.2017, 16:29  [ТС]
Спасибо за помощь)
0
Ответ Создать тему
Новые блоги и статьи
Установка 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/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru