-
Data: 2011-02-07 22:30:31
Temat: Re: parsowanie
Od: "Wojciech \"Spook\" Sura" <spook"mad@hatter"op.pl> szukaj wiadomości tego autora
[ pokaż wszystkie nagłówki ]Dnia 07-02-2011 o 21:23:26 Zbigniew Malec <a...@i...invalid>
napisał(a):
(...)
W moim parserze wyrażeń matematycznych zastosowałem wariant ze wstępną
(uproszczoną) analizą składniową. Fragment pliku wejściowego dla
generatora tokenizera wygląda tak:
# Stan 1 - Oczekiwanie na obiekt numeryczny
1,integer->2=[0-9]+
1,unaryoperator->1=(\-)|(\!)
1,variable->2=[a-zA-Z][a-zA-Z0-9]*
1,function->1=[a-zA-Z][a-zA-Z0-9]*\(
1,openparenthesis->1=\(
(...)
# Stan 2 - Oczekiwanie na operator
2,closeparenthesis->2=\)
2,operator->1=(\+)|(\-)|(\*)|(\/)|(\\)|(\%)|(\^)|(\<
\<)|(\>\>)|(\<)|(\>)|(\<\=)|(\>\=)|(\=\=)|(\!\=)|(\&
)|(\|)|(\#)
(...)
Czyli na przykład f(x*(3+4)) zostanie rozpoznane jako:
function, variable, operator, openparenthesis, integer, operator, integer,
closeparenthesis, closeparenthesis.
Analogicznie -2-3 jako:
unaryoperator integer operator integer
Moim zdaniem taka wstępna analiza składniowa jest bardzo wygodna, bo
pozwala na wczesne wykrycie podstawowych błędów składniowych. Jeśli na
przykład ktoś postawi operator binarny zaraz za nawiasem otwierającym -
gdzie oczekiwany jest obiekt numeryczny - pierwszy zaprotestuje tokenizer,
zgłaszając nie rozpoznany obiekt.
Jest też minus tego rozwiązania: błąd zgłoszony użytkownikowi nie jest
zbyt czytelny ("Nie rozpoznany token" lub "Nieprawidłowe wyrażenie" kontra
"Nieoczekiwane wystąpienie operatora binarnego"). Wszystko jednak zależy
od potrzeb :)
Pozdrawiam -- Spook.
--
Używam klienta poczty Opera Mail: http://www.opera.com/mail/
Następne wpisy z tego wątku
- 08.02.11 23:47 Zbigniew Malec
Najnowsze wątki z tej grupy
- Grok zaczął nadużywać wulgaryzmów i wprost obrażać niektóre znane osoby
- Can you activate BMW 48V 10Ah Li-Ion battery, connecting to CAN-USB laptop interface ?
- We Wrocławiu ruszyła Odra 5, pierwszy w Polsce komputer kwantowy z nadprzewodzącymi kubitami
- Ada-Europe - AEiC 2025 early registration deadline imminent
- John Carmack twierdzi, że gdyby gry były optymalizowane, to wystarczyły by stare kompy
- Ada-Europe Int.Conf. Reliable Software Technologies, AEiC 2025
- Linuks od wer. 6.15 przestanie wspierać procesory 486 i będzie wymagać min. Pentium
- ,,Polski przemysł jest w stanie agonalnym" - podkreślił dobitnie, wskazując na brak zamówień.
- Rewolucja w debugowaniu!!! SI analizuje zrzuty pamięci systemu M$ Windows!!!
- Brednie w wiki - hasło Dehomag
- Perfidne ataki krakerów z KRLD na skrypciarzy JS i Pajton
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- Instytut IDEAS może zacząć działać: "Ma to być unikalny w europejskiej skali ośrodek badań nad sztuczną inteligencją."
- U nas propagują modę na SI, a w Chinach naukowcy SI po kolei umierają w wieku 40-50lat
Najnowsze wątki
- 2025-07-23 Gdańsk => Programista Delphi <=
- 2025-07-23 Gdańsk => Programista Mainframe (z/OS, Assembler) <=
- 2025-07-23 Warszawa => Starszy inżynier DevOps (AWS) <=
- 2025-07-23 Gdańsk => Mainframe (z/OS, Assembler) Developer <=
- 2025-07-23 Kraków => Senior Fullstack Engineer (Low-Code Platform) <=
- 2025-07-23 Wrocław => Senior Key Account Manager IT <=
- 2025-07-23 Trójmiasto => Head of Social Media <=
- 2025-07-23 Rzeszów => Spedytor Międzynarodowy <=
- 2025-07-23 Lublin => ERP Implementation Consultant (AP Module) <=
- 2025-07-23 Środa Wielkopolska => SAP FI/CO Internal Consultant <=
- 2025-07-23 Warszawa => Inżynier oprogramowania .Net <=
- 2025-07-23 Kraków => Kotlin Developer <=
- 2025-07-23 Żerniki => Dyspozytor Międzynarodowy <=
- 2025-07-23 Warszawa => Java Developer <=
- 2025-07-23 Wrocław => Konsultant wdrożeniowy (systemy controlingowe) <=