%% ///////////////////////////////////////////////////////////////////////////// // rules section // place your Lex rules here "else" {printf("ELSE:%s%c ",yytext,' ');return ELSE;} "if" {printf("IF:%s%c ",yytext,' ');return IF;} "int" {printf("INT:%s%c ",yytext,' ');return INT;} "return" {printf("RETURN:%s%c ",yytext,' ');return RETURN;} "void" {printf("VOID:%s%c ",yytext,' ');return VOID;} "while" {printf("WHILE:%s%c ",yytext,' ');return WHILE;} "<" {printf("LT:%s%c ",yytext,' ');return LT;} ">" {printf("GT:%s%c ",yytext,' ');return GT;} "<=" {printf("LE:%s%c ",yytext,' ');return LE;} ">=" {printf("GE:%s%c ",yytext,' ');return GE;} "==" {printf("EQ:%s%c ",yytext,' ');return EQ;} "!=" {printf("NE:%s%c ",yytext,' ');return NE;} "{" {printf("{:%s%c ",yytext,' '); return '{';} "}" {printf("}:%s%c ",yytext,' '); return '}';} "(" {printf("(:%s%c ",yytext,' ');return '(';} ")" {printf("):%s%c ",yytext,' ');return ')';} "[" {printf("[:%s%c ",yytext,' ');return '[';} "]" {printf("]:%s%c ",yytext,' ');return ']';} "+" {printf("+:%s%c ",yytext,' ');return '+';} "-" {printf("-:%s%c ",yytext,' ');return '-';} "*" {printf("*:%s%c ",yytext,' ');return '*';} "/" {printf("/:%s%c ",yytext,' ');return '/';} "%" {printf("%:%s%c ",yytext,' ');return '%';} ";" {printf(";:%s%c ",yytext,' ');return ';';} "=" {printf("=:%s%c ",yytext,' ');return '=';} "," {printf(",:%s%c ",yytext,' ');return ',';} {id} {printf("id:%s%c ",yytext,' ');return ID;} {number} {printf("number:%s%c ",yytext,' '); return NUMBER;} "/*" { char c; int done = FALSE; ECHO; do { while((c=input())!='*') putchar(c); putchar(c); while((c=input())=='*') putchar(c); putchar(c); if(c=='/') done =TRUE; } while(!done); printf("\n: There are the conment!"); return COMMENT; } %% 程序可以正确的运行,供有需要的同学使用
2024-03-27 13:25:53 39KB lex词法分析器
1
(网上转的一篇关于Lex的文章,比较不错,共享) Lex 帮助书写其控制流由在输入流中的正则表达式的实例来导向的程序。它适合于编辑器脚本类型的变换,和为解析例程做准备工作而分解输入。 Lex 源码是正则表达式和相应的程序片段的表格。Lex 把这个表格变换成读取输入流、复制它到输出流、并把输入划分到匹配给定表达式的字符串中的一个程序。随着每个这种字符串被识别出来,相应的程序片段就被执行。表达式通过用 Lex 生成的确定有限自动机来识别。用户书写的程序片段按照对应的正则表达式在输入流中出现的次序来执行。
2022-11-22 19:27:35 224KB Lex 词法分析
1
LEX实现一个C语言子集的词法分析器,该词法分析器读入一个C语言的源程序,完成有以下功能。  滤掉空格。(其中空白符、制表符和换行符均视为空格,用来分隔单词)  滤掉注释。(其中注释包括两种形式:/*…*/和//)  遇到非法单词时可显示“Error”,然后跳过错误部分继续显示  将识别出来的合法单词分为以下五大类,依次输出各个单词的内部编码(编码为1—5,如下)及单词符号自身值。
2022-03-28 15:23:29 2KB lex 词法分析器
1
编译原理 课程设计 基于lex词法分析器构造的源代码
2022-01-15 00:01:55 4KB 编译原理课程设计 lex 词法分析
1
《编译原理》词法分析程序设计方案,用C语言编写的词法分析器!
2021-12-11 23:32:55 6KB lex 词法分析器
1
实验二 词法分析器 一、实验目的 掌握词法分析器的构造原理,掌握手工编程或LEX编程方法之一。 二、实验内容 编写一个LEX源程序,使之生成一个词法分析器,能够输入的源程序转换为单词序列输出。 三、实验环境 Flex+VC6.0 四、实验注意 1.Id正则表达式:{letter}({letter}|{digit})* 2.Num正则表达式:{digit}+(\.{digit}+)?(E[+-]?{digit}+)? 3.注释:(\/\*(.)*\*\/) 4.关键字再加上其他字符就又能编程id,所以在词法分析时,id的判断应该放在关键字前面,这样才不会误判 5.由于本程序知识简单的打印数字,因此没有考虑数字的转换 6.">="比">"多一个字符,它应该放在前面判断,其他类似的也应该如此安排 五、实验代码 ******************************************************************************* 实验文件:lex.l、lex.yy.c 实验结果:lex.exe 运行方式:打开lex.exe,弹出input.txt,在其中输入所要测试的程序,保存并关闭,即可在output.txt中看到所得结果 ******************************************************************************* %{ void Install(char *type); %} %option noyywrap delim [ \t] newline [\n] digit [0-9] num {digit}+(\.{digit}+)?(E[+-]?{digit}+)? letter [A-Za-z] id {letter}({letter}|{digit})* key ("if"|"while"|"do"|"break"|"true") basic ("int"|"float"|"bool"|"char") op (">="|""|"<"|"="|"!="|"+"|"-"|"*"|"/") comment (\/\*(.)*\*\/) %% delim {;} newline {printf("\n");} {num} {Install("Num");} {key} {Install("Key");} {basic} {Install("Basic");} {op} {Install("Op");} ";" {Install("Comma");} {id} {Install("ID");} {comment} {Install("Comment");} "(" | "[" | "{" {Install("lbracket");} ")" | "]" | "}" {Install("rbracket");} %% void Install(char *s) { fprintf(yyout, "%s:%s ", s, yytext); } int main() { printf("please input the test program in input.txt\n"); system("input.txt"); yyin = fopen("input.txt", "r"); yyout = fopen("output.txt", "w" ); yylex(); fclose(yyout); fclose(yyin); printf("analysis result in output.txt\n"); system("output.txt"); return 0; } 六、实验小结 本次的实验由于使用了flex,所以代码较短,麻烦的事flex的正则式表达,由于该使用规则只有简单介绍,而网上找的教程难免有比重就轻之嫌,所以得到上述表达式着实费力,且有的没有成功,例如bracket的(\ ((.)*\ ))或者("("(.)*")")使用时都没有成功,所以便单独写出,有点不伦不类。至于其他的,都较为简单,完。
2021-03-23 17:07:36 402KB lex词法分析器 编译原理
1
编译原理课程设计/实验 lex简单词法分析器 只实现了简单功能
2019-12-21 21:27:03 4KB 编译原理 lex 词法分析器 课程设计
1
一个简单的词法分析器例子,运用lex编程实现将一段C语言程序转换为词法单元识别。
2019-12-21 21:26:45 716KB 词法分析器 代码 C++ lex
1
使用lex语言编写一个词法分析器,在文档中已说得很清楚,有什么问题可以留言,大家一起探讨探讨,其实对于lex语言我也有不懂的地方,其中我想把关键字给识别出来就没做出来,所以有会的可以告诉一下啊,先谢了
2019-12-21 19:25:40 184KB flex lex 词法分析器
1