2013-03-26 53 views
0

再次在NLP执行我的代码一些问题,一个小错误.. 在pro.l文件我有几个模式和他们的行动... Pro.l建议在lex和yacc

%{ 
#include <stdio.h> 
#include <stdlib.h> 
#include <string.h> 
void yyerror(char *str); 
%} 
%% 

[\t] ; 
[a-zA-Z]+ { yylval = strdup(yytext) ; return INPUT ; } /* may be this line is source of error . It has been written so as to include Junk words */ 
"is equal to" { return CONDITION ; } 
"whose" { return WHOSE ; } 
"by"  { return PREP ; } 
"any" { return QUALIFIER ; } 
"our" { return QUALIFIER ; } 
"show" { return ASK ; } 
"list" { return ASK ; } 
"display us" { return ASK ; } 
"and" { return WORD ; } 
"every" { printf("%s \n", yylval) ; return QUALIFIER ; } 
"of every" { return QUALIFIER ; } 
"all" { printf("%s \n", yylval) ; return QUALIFIER ; } 
"name" { yylval = strdup(yytext) ; printf("%s \n", yylval) ; return FIELD ; } 
"id" { yylval = strdup(yytext) ; return FIELD ; } 
"the" { return QUALIFIER ; }  
"how many" { return MOJ ; } 
"count" { return MOJ ; } 
"book" { yylval = strdup(yytext) ; printf("%s \n", yylval) ; return TABLE ; } 
"?" { return EOL ; } 
"." { return EOL ; } 
%% 

上面给出的是pro.l,我想要包括一个模式[a-zA-Z]+ action但它不允许我这样做,并给出错误。我想包括这种模式,以便我可以容纳我的程序中的任何垃圾词。

下面给出的是pro.y

%{ 
#include <stdio.h> 
#include <stdio.h> 
#include <string.h> 
#define YYSTYPE char *   
extern char *yytext ; 

int yylex(void) ; 
static void yyerror(char *str) 
{ 
    printf("yyerror : %s " , str) ; 
} 
%} 

%error-verbose 
%token ASK 
%token PREP 
%token QUALIFIER 
%token MOJ 
%token WORD 
%token TOTAL 
%token EOL 
%token TABLE 
%token FIELD 
%token WHOSE 
%token CONDITION 
%token INPUT 

%% 

translate : select 
      | count 
      ;                                     


select : ASK QUALIFIER TABLE EOL { printf("SELECT DISTINCT * FROM %s",$3) ;} 
     | ASK FIELD QUALIFIER TABLE EOL  { printf("SELECT %s FROM %s",$2,$4) ;}  
     | ASK QUALIFIER TABLE FIELD EOL { printf("SELECT DISTINCT %s FROM %s ",$4 ,$3) ;} 
     | ASK QUALIFIER FIELD WORD FIELD QUALIFIER TABLE EOL { printf("SELECT DISTINCT %s , %s FROM %s", $3, $5, $7) ;} 
     | ASK QUALIFIER TABLE WHOSE FIELD CONDITION INPUT EOL { printf("SELECT DISTINCT * FROM %s WHERE %s =", $3, $5); } 
     |  
     ; 

count : MOJ TABLE EOL { printf("SELECT COUNT(*) FROM %s", $2) ;} 
     | ASK TABLE MOJ EOL { printf("SELECT COUNT(*) FROM %s", $2); } 
     | MOJ TABLE PREP FIELD EOL {printf("SELECT COUNT(*) FROM %s WHERE %s = ",$2 ,$4) ;} 
     ; 
%% 

#include "lex.yy.c" 
extern int yylex() ; 
extern int yyparse() ; 
extern FILE *yyin ; 
int main() 
{ 
    FILE *myfile = fopen("sample.txt" , "r") ; 
    if(!myfile) 
    { 
     printf("Can't open the file ") ; 
     return -1 ; 
    } 
    yyin = myfile ; 
    do 
    { 
     yyparse(); 
    }while(!feof(yyin)) ; 
    yylex_destroy() ; 
    return 0 ; 
} 

请建议我一些方法,以适应在法文件的当前模式不是代表的垃圾话。

Errors stmts:i/p - >向我们显示名称等于xyz的书。

错误 - > yyerror:语法错误,意外的INPUT,期望QUALIFIER或TABLE或FIELD。

附::垃圾这样的词:xyz,abc,fgfhg,jhyjg898等

+0

欢迎登机。请包括您收到的未经编辑的错误消息,并附上您的问题。谢谢。 – 2013-03-26 16:54:40

+0

已将错误包含在问题语句以及我想包含的命令/模式中 – jose 2013-03-26 17:31:06

+2

将其他规则放在一起。 – 2013-03-26 21:26:59

回答

0

您已经把[a-zA-Z]+(Jonathan的全部)作为第一条规则。如果含糊不清,lex会采用最长的匹配模式。如果两个模式匹配一​​个相同长度的字符串,那么将采用第一个模式。因此,通过首先放置全部,它也将匹配其他关键字,如whose。这就是为什么乔纳森说这是最后一条通用规则。这样所有的关键字将首先匹配,只有当它们不匹配时才会被使用。

+0

谢谢你,得到它......感谢乔纳森 – jose 2013-03-27 13:27:36