Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.54/13: Рейтинг темы: голосов - 13, средняя оценка - 4.54
4 / 3 / 0
Регистрация: 22.08.2014
Сообщений: 80

Проверка формата ввода аргументов командной строки регулярными выражениями

24.06.2017, 02:33. Показов 2749. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Часто при запуске программы на вход подаются дополнительные данные в определённом формате (взять хоть компиляцию с флагами). Валидация поданного, с учётом проверок числа аргументов, их вида и положения относительно друг друга всегда выливается в целую кучу if-else и т.п. Появилась идея сделать это с помощью регулярного выражения. Видит ли кто-нибудь здесь проблемы (кроме тех, что нужен c++11 и уже разбитую на токены строку придётся "сшивать" обратно), и какой самый удобный инструмент для проведения подобных проверок, на ваш взгляд?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
24.06.2017, 02:33
Ответы с готовыми решениями:

Проверка текста регулярными выражениями
Как реализовать проверку текста используя регулярные выражения? Для проверки например, того же email

Проверка аргументов командной строки
Код вызывающий программу (интерфейс для работы с разными программами): { int caesar = ui.key->value(); char *_fileWay =...

Проверка email на валидность регулярными выражениями
Есть задача: проверить вводимый email на валидность. Можно сделать это ручками, а можно через регулярные выражения попробовать. Нашел...

5
зомбяк
 Аватар для TRam_
1585 / 1219 / 345
Регистрация: 14.05.2017
Сообщений: 3,940
24.06.2017, 02:40
Цитата Сообщение от VergilYamato Посмотреть сообщение
уже разбитую на токены строку придётся "сшивать" обратно
сшивать нужно только при условии обнаружения и автоматического исправления ошибок, а так можно ж заранее сделать копию...

Добавлено через 2 минуты
Цитата Сообщение от VergilYamato Посмотреть сообщение
в целую кучу if-else
ещё switch есть . И, если говорить в общем, https://ru.wikipedia.org/wiki/Конечный_автомат , частным случаем которого и являются регулярные выражения.
0
4 / 3 / 0
Регистрация: 22.08.2014
Сообщений: 80
24.06.2017, 02:53  [ТС]
Я имею в виду, что аргументы командной строки уже разбиты и находятся в argv массиве по отдельности, и проверять их по отдельности, опять же, не очень удобно (уже упомянутые количество аргументов и их положение относительно друг друга), поэтому логичным выглядит их конкатенация в одну строку и уже её исследование регулярным выражением.

Добавлено через 6 минут
Цитата Сообщение от TRam_ Посмотреть сообщение
ещё switch есть . И, если говорить в общем, https://ru.wikipedia.org/wiki/Конечный_автомат , частным случаем которого и являются регулярные выражения.
Честно говоря, никогда не писал конечный автомат "руками", но, учитывая, что нужно будет задавать все состояния и переходы из одного в другое, if-else выглядит проще и быстрее . Switch не учитывает, что при одном и том же числе аргументов, они могут выглядеть по разному и потребуются дополнительные проверки, чтобы удостовериться, что всё подано верно.
0
Эксперт С++
 Аватар для hoggy
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
24.06.2017, 13:54
Лучший ответ Сообщение было отмечено VergilYamato как решение

Решение

Цитата Сообщение от VergilYamato Посмотреть сообщение
Валидация поданного, с учётом проверок числа аргументов, их вида и положения относительно друг друга всегда выливается в целую кучу if-else и т.п. Появилась идея сделать это с помощью регулярного выражения.
попробуйте сделать.
как вы вообще себе это представляете?
Цитата Сообщение от VergilYamato Посмотреть сообщение
Видит ли кто-нибудь здесь проблемы
не гибкое и не юзер-френдли решение.

вот например:

Code
1
copy_if    /maxsize=15mb   src dst
задача не только выполнить общую валидацию входного синтаксиса.
с выдачей деталей возможных ошибок.

но и возможность реагировать на наличие тех, или иных ключей.

в данном случае, если в строке обнаружен ключ "maxsize",
то это событие нужно как то индентифицировать и обработать.
извлечь/сохранить значение параметра "максимальный размер".

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

по итогу, при попытке разбора реальных командных строк
для реальных задач, реальных программ,
вы неизбежно опять окажитесь там,
откуда все началось - кучка if`ов,
со всевозможными проверками,
и реакциями на те, или иные ситуации.

язык регулярок здесь никак не поможет.

конструктор для быстрого разбора командной строки это
- лексический/синтаксический анализатор в одном флаконе.

ну или смотрите в сторону недобитых костылей аля boost:rogram_options
https://habrahabr.ru/post/174347/
1
4 / 3 / 0
Регистрация: 22.08.2014
Сообщений: 80
25.06.2017, 03:55  [ТС]
Ну, например, для следующего формата ввода:
"mytest [-n NNN] in.txt out.txt
N может быть задано опциональным ключом командной строки "-n"."
я организовал проверку следующим образом.
C++
1
2
3
4
5
6
7
8
        std::string input;
    for(int i = 1; i < argc; i++)
        input += std::string(argv[i]) + std::string(" ");
    std::regex e("(-n [\\d]+ ){0,1}(.+) (.+) ");
    if(!std::regex_match(input, e))
        {
        .........//Дальнейший код
        }
0
Эксперт С++
 Аватар для hoggy
8973 / 4319 / 960
Регистрация: 15.11.2014
Сообщений: 9,760
25.06.2017, 06:36
Цитата Сообщение от VergilYamato Посмотреть сообщение
Ну, например, для следующего формата ввода:
ваш пример не работает.
точных причин не назову.
поскольку вам было впадлу привести пример-иллюстрацию компилирующегося кода,
то мне - тем более.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.06.2017, 06:36
Помогаю со студенческими работами здесь

Проверка на наличие подстроки регулярными выражениями
Здравствуйте. С помощью регулярных выражений я пытаюсь проверить наличие подстроки. Для этого пишу такой код: std::regex...

Работа с регулярными выражениями - проверка окончаний слов
Есть Паттерн: private static string AdjectivePattern =...

Как найти регулярными выражениями перенос строки?
&lt;tr&gt; &lt;td &gt;Строка 1&lt;/td&gt; &lt;td &gt;Строка 2&lt;/td&gt; &lt;td &gt;Строка 3&lt;/td&gt; &lt;td &gt;Строка 4&lt;/td&gt; &lt;/tr&gt; Как можно найти регулярными выражениями...

Поиск строки между указанными строками Регулярными выражениями
У меня есть строка, из которой нужно достать слово, которое находится между двумя указанными подстроками, но также оно может и стоять в...

Очистка строки содержащей число от посторонних символов, с регулярными выражениями
Всем добрый день, Возникла необходимость обработать ту белиберду что вводит пользователь (в TextBox) в строку которая без проблем...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru