欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言中使用lex統(tǒng)計文本文件字符數(shù)

 更新時間:2015年04月08日 09:29:38   投稿:junjie  
這篇文章主要介紹了C語言中使用lex統(tǒng)計文本文件字符數(shù),本文直接給出實現(xiàn)代碼,需要的朋友可以參考下

我曾經(jīng)在Linux上寫的一個C程序,借助Lex做詞法分析來同時統(tǒng)計N個文本文件的字符數(shù),單詞數(shù)和行數(shù)。讓我覺得Lex確實挺有意思的。確實Lex的功能非常強大,用來做小巧的詞法分析非常適合,也非常好用。這個程序參考了《Lex與Yacc》上的一個例子。

%{ 
unsigned int char_count = 0, word_count = 0, line_count = 0; 
%} 
%% 
[^ /t/n]+ {word_count++; char_count+=yyleng;}; 
/n {char_count++; line_count++;}; 
. char_count++; 
%% 
char **file_list; 
unsigned int current_file = 0; 
unsigned int total_file = 0; 

unsigned int total_cc = 0; 
unsigned int total_wc = 0; 
unsigned int total_lc = 0; 

typedef struct file_info{ 
  unsigned int c; 
  unsigned int w; 
  unsigned int l; 
  char *name; 
}INFO; 

INFO **all; 


int create_info(int num) 
{ 
  INFO *tmp; 
  int i; 
  if (num <= 0){ 
    return -1; 
  } 
  all = (INFO **)malloc(sizeof(int *)*num); 
  for (i = 0; i < num; i++){ 
    tmp = (INFO *)malloc(sizeof(INFO)); 
    tmp->c = 0; 
    tmp->w = 0; 
    tmp->l = 0; 
    tmp->name = NULL; 
    all[i] = tmp; 
  } 
  return 1; 
}   

int delete_info(int num) 
{ 
  int i; 
  if ((all == (INFO **)0) || num <= 0){ 
    return -1; 
  } 
  for (i = 0; i < num; i++){ 
    free(all[i]); 
  } 
  free(all); 
  return 1; 
} 

int set_info(int pos) 
{ 
  int length = 0; 
  if (pos < 0){ 
    return -1; 
  } 
  all[pos]->c = char_count; 
  all[pos]->w = word_count; 
  all[pos]->l = line_count;   
  all[pos]->name = file_list[pos]; 
   
  return 1; 
} 

int main(int argc, char** argv) 
{ 
  FILE *file;   
  int position = 0; 
  int i; 
   
  file_list = argv + 1; 
  total_file = argc - 1; 
  current_file = 0; 
   
  printf("--------------------------------------------------------------/n", 
 total_file);  
  
  if (argc > 1){ 
    if (create_info(total_file) == -1){ 
      fprintf(stderr, "%s/n", "Encounter a error when malloc memory."); 

      exit(1); 
    } 
  } 
  if (argc == 2){        
     
    file=fopen(argv[1], "r"); 
    if (!file){ 
      fprintf(stderr, "Could not open %s./n", argv[1]); 
      delete_info(total_file); 
      exit(1); 
    }     
    yyin = file; 
  } 
   
  yywrap(); 
  yylex(); 
  
  if (argc > 1){ 
    total_cc += char_count; 
    total_wc += word_count; 
    total_lc += line_count;     
     
    if (set_info(current_file-1) == -1){ 
      fprintf(stderr, "%s/n", "Encounter a error when set information to 
 INFO."); 
      delete_info(total_file); 
      exit(1); 
    }     
     
    for (i = 0; i < total_file; i++){ 
      printf("char:%-8lu word:%-8lu line:%-8lu file name:%s/n", all[i]-> 
c, all[i]->w, all[i]->l, file_list[i]); 
    } 
    printf("----------------------- total -------------------------------- 
/n"); 
    printf("chars:%-8lu words:%-8lu lines:%-8lu files:%d/n", total_cc, tot 
al_wc, total_lc, total_file); 
  }else{     
    printf("char:%-8lu word:%-8lu line:%-8lu/n", char_count, word_count, l 
ine_count); 
  } 
   
  delete_info(total_file); 
  return 0; 
} 
 
yywrap() 
{ 
  FILE *file = NULL; 
   
  if ((current_file > 0) && (current_file < total_file) && (total_file > 1)) 
{ 
    total_cc += char_count; 
    total_wc += word_count; 
    total_lc += line_count; 
     
    if (set_info(current_file-1) == -1){ 
      fprintf(stderr, "%s/n", "Encounter a error when set information to 
 INFO."); 
      delete_info(total_file); 
      exit(1); 
    }   
     
    char_count = word_count = line_count = 0; 
    fclose(yyin);     
  } 
  while ((file_list[current_file] != (char *)0) && (current_file < total_fil 
e)){ 
     
    file = fopen(file_list[current_file++], "r"); 
    if (!file){ 
      fprintf(stderr, "could not open %s .", file_list[current_file - 1] 
); 
    }else{ 
      yyin = file; 
      break; 
    } 
  } 
  return (file? 0 : 1); 
} 

相關文章

  • C語言的動態(tài)內(nèi)存分配及動態(tài)內(nèi)存分配函數(shù)詳解

    C語言的動態(tài)內(nèi)存分配及動態(tài)內(nèi)存分配函數(shù)詳解

    這篇文章主要為大家詳細介紹了C語言的動態(tài)內(nèi)存分配及動態(tài)內(nèi)存分配函數(shù),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • C 語言二叉樹幾種遍歷方法詳解及實例

    C 語言二叉樹幾種遍歷方法詳解及實例

    這篇文章主要介紹了C 語言二叉樹幾種遍歷方法詳解及實例的相關資料,二叉樹在數(shù)據(jù)結(jié)構(gòu)當中是非常重要的知識要點,這里對二叉樹進行了總結(jié),需要的朋友可以參考下
    2017-01-01
  • C++實現(xiàn)指針空值的示例代碼

    C++實現(xiàn)指針空值的示例代碼

    本文主要介紹了C++實現(xiàn)指針空值的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • C++分析講解類的靜態(tài)成員變量是什么

    C++分析講解類的靜態(tài)成員變量是什么

    在C++中,靜態(tài)成員是屬于整個類的而不是某個對象,靜態(tài)成員變量只存儲一份供所有對象共用。所以在所有對象中都可以共享它。使用靜態(tài)成員變量實現(xiàn)多個對象之間的數(shù)據(jù)共享不會破壞隱藏的原則,保證了安全性還可以節(jié)省內(nèi)存
    2022-04-04
  • C語言算法金手指摩爾投票法手撕絕大多數(shù)問題

    C語言算法金手指摩爾投票法手撕絕大多數(shù)問題

    這篇文章主要為大家介紹了C語言算法之金手指摩爾投票法手撕絕大多數(shù)問題的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2022-02-02
  • c++統(tǒng)計文件中字符個數(shù)代碼匯總

    c++統(tǒng)計文件中字符個數(shù)代碼匯總

    本文給大家匯總介紹了3種使用C++實現(xiàn)統(tǒng)計文件中的字符個數(shù)的方法,非常的簡單實用,有需要的小伙伴可以參考下。
    2015-09-09
  • C++計算ICMP頭的校驗和實例

    C++計算ICMP頭的校驗和實例

    這篇文章主要介紹了C++計算ICMP頭的校驗和的方法,代碼簡單實用,對于校驗ICMP報文來說有不錯的實用價值,需要的朋友可以參考下
    2014-10-10
  • C語言掃雷游戲的簡單實現(xiàn)

    C語言掃雷游戲的簡單實現(xiàn)

    這篇文章主要為大家詳細介紹了C語言掃雷游戲的簡單實現(xiàn),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • pthread_cond_wait() 用法深入分析

    pthread_cond_wait() 用法深入分析

    以下是對pthread_cond_wait的用法進行了詳細的分析介紹,需要的朋友可以過來參考下
    2013-07-07
  • C語言實現(xiàn)簡易掃雷小游戲

    C語言實現(xiàn)簡易掃雷小游戲

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)簡易掃雷小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10

最新評論