Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Синтаксис
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 28.12.2009, 17:33
Vidog Vidog вне форума
Прохожий
 
Регистрация: 18.09.2009
Сообщения: 2
Репутация: 10
По умолчанию Разбор и парсер строк

У меня есть строка вида
Код:
"Привет, " + func({name}) + "! " + func2("Абв", "Где") + {test}

разберу:
"Привет, " - обычная строка, заключенная в кавычки
func({name}) - какая-то функция, единственным параметром которой является переменная name (переменные заключены между "{" и "}")
"! " - далее опять строка
func2("Абв", "Где") - еще функция, у которой 2 параметра.
{test} - просто переменная

Мне нужно, чтобы на выходе у меня был массив, содержащий все элементы данной строки.
[0] - "Привет, "
[1] - func({name})
итд..

В чем собственно вопрос.. Здесь в этой строке ничего особо сложного нет - на выходе 5 простых элементов, сложность в том, что элемент может быть такой:
func({name} + func2("aaa", "bbb"), "test", func3("abcde"))
т.е внутри самой функции параметры тоже имеют элементы..

Задачка у меня построить древовидную структуру разобранной строки строки.. Например, вывести ее в TTreeView.
  • "Привет, "
  • func()
    • {name}
  • "! "
  • func2()
    • "Абв"
    • "Где"
  • {test}

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

помогите, пожалуйста

Последний раз редактировалось Vidog, 28.12.2009 в 17:37.
Ответить с цитированием
  #2  
Старый 28.12.2009, 18:19
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,032
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Считай скобки.
Т.е. идешь по строке.
Если находишь откр. скобку - увеличиваешь счетчик скобок на 1. Если находишь закрывающую скобку - уменьшаешь. Если нашел +, то если счетчик = 0, то отделяешь лексему, если нет - идешь дальше. Все отделенные лексемы опять загоняешь в ту же функцию. Ну а как при этом дерево строить - сам разберешься
Ответить с цитированием
  #3  
Старый 28.12.2009, 18:43
Vidog Vidog вне форума
Прохожий
 
Регистрация: 18.09.2009
Сообщения: 2
Репутация: 10
По умолчанию lmikle

Можешь программно построить алгоритм, пожалуйста?)
Хотя вроде получается, сейчас покажу что выйдет..

Последний раз редактировалось Vidog, 28.12.2009 в 18:52.
Ответить с цитированием
  #4  
Старый 28.12.2009, 20:13
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,032
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Могу.
Но если это буду делать я - то не бесплатно. Если у тебя ошибки поискать - всегда пожалуйста (но это не значит, что я буду отлаживать твою программу )
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 11:14.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter