用c語言基本實現wc.exe功能

来源:https://www.cnblogs.com/abc123def456/archive/2018/09/15/9649762.html
-Advertisement-
Play Games

網址:https://github.com/3216005214/wc.exe wc項目要求 wc.exe 是一個常見的工具,它能統計文本文件的字元數、單詞數和行數。這個項目要求寫一個命令行程式,模仿已有wc.exe 的功能,並加以擴充,給出某程式設計語言源文件的字元數、單詞數和行數。 實現一個統計 ...


網址:https://github.com/3216005214/wc.exe

wc項目要求

wc.exe 是一個常見的工具,它能統計文本文件的字元數、單詞數和行數。這個項目要求寫一個命令行程式,模仿已有wc.exe 的功能,並加以擴充,給出某程式設計語言源文件的字元數、單詞數和行數。

實現一個統計程式,它能正確統計程式文件中的字元數、單詞數、行數,以及還具備其他擴展功能,並能夠快速地處理多個文件。
具體功能要求:
程式處理用戶需求的模式為:

wc.exe [parameter] [file_name]

 基本功能列表:

wc.exe -c file.c     //返迴文件 file.c 的字元數

wc.exe -w file.c    //返迴文件 file.c 的詞的數目  

wc.exe -l file.c      //返迴文件 file.c 的行數

擴展功能:
    -s   遞歸處理目錄下符合條件的文件。
    -a   返回更複雜的數據(代碼行 / 空行 / 註釋行)。

空行:本行全部是空格或格式控制字元,如果包括代碼,則只有不超過一個可顯示的字元,例如“{”

代碼行:本行包括多於一個字元的代碼。

註釋行:本行不是代碼行,並且本行包括註釋。一個有趣的例子是有些程式員會在單字元後面加註釋:

    } //註釋
在這種情況下,這一行屬於註釋行。

[file_name]: 文件或目錄名,可以處理一般通配符。

高級功能:

 -x 參數。這個參數單獨使用。如果命令行有這個參數,則程式會顯示圖形界面,用戶可以通過界面選取單個文件,程式就會顯示文件的字元數、行數等全部統計信息。

需求舉例:
  wc.exe -s -a *.c

返回當前目錄及子目錄中所有*.c 文件的代碼行數、空行數、註釋行數。

已實現wc項目要求

1、計算文件字元數

2、計算文件單詞數

3、計算文件行數

4、計算文件空行數

遇到的困難及解決辦法

▪  困難描述

大學前兩年對課程學習的疏忽,對c語言的知識的記憶已經大大減少,以至於老師要求我們做這個單人項目的時候,心裡是慌的,因為對c語言等編程的不熟悉,所以我要花幾天時間重新把丟下的知識重新拾取回來,所以,我也就比別人的時間要更緊張。首先我先做了下嘗試,嘗試用JAVA和C語言寫這個項目,最後還是選擇了C語言。在寫代碼的過程中,有許多新的函數未接觸過,需要花時間去瞭解。還有github的使用方法也不是太瞭解,也要花時間去做。對於傳參的形式也是想了很久,做出了很多嘗試。

▪  做過哪些嘗試

對於要重拾C語言知識這件事情,幸好大一的時候買了一本較為詳細的C語言教科書,幫助我能更快的把丟下的知識拿回來。當演算法真的不懂的時候,到網上參考了一些代碼,然後把它理解為自己的東西再寫到自己的代碼中。在把第一個基本功能寫出的時候,運行的時候發現總是只能讀取文件中的第一個字元,通過不斷的檢查,嘗試,終於才可以正確的實現計算字元數的功能。對於傳參形式,首先嘗試用了指針,然後發現行不通(可能以我現在水平不能很好的使用這種方法),最後用了數組,選擇了一種比較簡單的方式。在函數的選擇方面,也是一個一個認為可以實現的函數去嘗試(雖然最後沒有用到多少函數)

▪  是否解決

拓展功能的註釋行和代碼行的計數演算法尚未解決,空行的計數方法存在缺陷。基本功能已實現。

▪  有何收穫

瞭解並基本掌握關於處理文件的演算法函數

重拾C語言相關知識

認識到需要不斷鞏固知識的重要性

關鍵代碼及說明

 

int main(){//主函數 
    char input[10],File[200];
    while(1){
        printf("請輸入用戶命令:wc.exe-");
        scanf("%s",&input);
        if(input[0]=='c'){
           printf("請輸入文件名:");
           scanf("%s",&File);
           int charcount=0;
           charcount=CharCount(File);
           printf("文件的字元數為:%d\n",charcount);
           continue;    
        }
        if(input[0]=='w'){
            printf("請輸入文件名:");
            scanf("%s",&File); 
            int wordcount=0;
            wordcount=WordCount(File);
            printf("文件的詞數為:%d\n",wordcount);
            continue;
        }
        if(input[0]=='l'){
            printf("請輸入文件名:");
            scanf("%s",&File); 
            int linecount=0;
            linecount=LineCount(File);
            printf("文件的行數為:%d\n",linecount);
            continue;    
        }
        if(input[0]=='a'){
            printf("請輸入文件名:");
            scanf("%s",&File); 
            ComplexCount(File);
            continue;
        }
    }
    system("pause");
    return 0;
}

 

 

主函數:運用傳參的方法

int CharCount(char file[]){//字元數統計函數 
    FILE *pf=NULL;
    int ccount=0;
    pf=fopen(file,"r");
    if(pf==NULL){
        printf("尋找文件失敗\n");
        exit(-1);
    }
    char mychar;
    mychar = fgetc(pf);
    while(mychar!=EOF){
        mychar = fgetc(pf);
        ccount++;
    }
    fclose(pf);
    return ccount;
}

字元統計函數:在每次讀取文件中的字元時,ccount+1

int WordCount(char file[]){//單詞數統計函數 
    FILE *pf=NULL;
    int wcount=0;
    pf=fopen(file,"r");
    if(pf==NULL){
        printf("尋找文件失敗\n");
        exit(-1);
    }
    char mychar;
    mychar = fgetc(pf);
    while(mychar!=EOF){
        if(mychar>='a'&&mychar<='z'||mychar>='A'&&mychar<='Z'||mychar>='0'&&mychar<='9'){
            while(mychar>='a'&&mychar<='z'||mychar>='A'&&mychar<='Z'||mychar>='0'&&mychar<='9'||mychar=='_'){
                mychar=fgetc(pf);
            }
            wcount++;
            mychar=fgetc(pf);
        }
        mychar=fgetc(pf);
    }
    fclose(pf);
    return wcount;
}

 

單詞統計函數

int LineCount(char file[]){//行數統計函數 
    FILE *pf=NULL;
    int lcount=0;
    pf=fopen(file,"r");
    if(pf==NULL){
        printf("尋找文件失敗\n");
        exit(-1);
    }
    char mychar;
    mychar = fgetc(pf);
    while(mychar!=EOF){
        if(mychar=='\n'){
            lcount++;
            mychar = fgetc(pf);
        }
        else{
            mychar = fgetc(pf);
        }
    }
    
    fclose(pf);
    return lcount+1;
}

 

行數統計函數

int ComplexCount(char file[]){
    FILE *pf=NULL;
    int spacecount=0;
    pf=fopen(file,"r");
    if(pf==NULL){
        printf("尋找文件失敗\n");
        exit(-1);
    }
    char mychar;
    mychar = fgetc(pf);
    while(mychar!=EOF){
        if(mychar=='\n'){
            mychar=fgetc(pf);
            if(mychar=='\n' ){
                spacecount++;
                mychar=fgetc(pf);
            }
        }
        else if(mychar=='}'){
            mychar=fgetc(pf);
            if(mychar=='\n'){
                spacecount++;
                mychar=fgetc(pf);
            }
        }
        else mychar=fgetc(pf);
    }
    printf("文件空行數為%d\n",spacecount);
    return 0;
}

空行統計函數:該演算法有缺陷,不嚴謹

測試結果

                    

              

PSP

PSP2.1

Personal Software Process Stages

預估耗時(分鐘)

實際耗時(分鐘)

Planning

計劃

30

30

· Estimate

· 估計這個任務需要多少時間

24*60

2*24*60

Development

開發

10*60

12*60

· Analysis

· 需求分析 (包括學習新技術)

15

10

· Design Spec

· 生成設計文檔

5

5

· Design Review

· 設計覆審 (和同事審核設計文檔)

10

10

· Coding Standard

· 代碼規範 (為目前的開發制定合適的規範)

15

15

· Design

· 具體設計

30

60

· Coding

· 具體編碼

5*60

5*60

· Code Review

· 代碼覆審

15

30

· Test

· 測試(自我測試,修改代碼,提交修改)

15

15

Reporting

報告

20

30

· Test Report

· 測試報告

15

20

· Size Measurement

· 計算工作量

10

10

· Postmortem & Process Improvement Plan

· 事後總結, 並提出過程改進計劃

15

15

合計

 

2535

4150

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 遞四方速遞發燒qwerwee 阿斯頓發斯蒂芬 廢物廢物權恩菲 ...
  • (“#panel”).bind(“click”,function(){ 與$(“#panel”).click(function(){ 有什麼區別 ? 綁定可以同時加多個事件 為每一個匹配元素一個或多個事件綁定事件處理器函數。 你可以在事件處理之前傳遞一些附加的數據。 ...
  • HeBeiTianQi.jsp頁面 HeBeiTianQi.js ...
  • 1 <head> 2 <link href="static/bootstrap-3.3.5-dist/css/bootstrap.css" rel="stylesheet" /> 3 <link href="static/bootstrap-table/bootstrap-table.css" re ...
  • layer_test.jsp bootstrap_model_test.jsp ...
  • 網路編程 一. 1.網卡: 電腦中有網卡,網卡中有mac地址. 2.IP: 插上網線,路由器或交換機中的DHCP服務會自動分配IP地址. IP:192.168.13.150 IPv4: 00000000.00000000.00000000.00000000 0-255 0-255 0-255 0-2 ...
  • Can't debug c++ project because unable to static library start program *.lib Can't debug c++ project because unable to static library start program *. ...
  • RPC調用 多個服務協同完成一次業務時,由於業務約束(如紅包不符合使用條件、賬戶餘額不足等)、系統故障(如網路或系統超時或中斷、資料庫約束不滿足等),都可能造成服務處理過程在任何一步無法繼續,使數據處於不一致的狀態。傳統的基於資料庫本地事務的解決方案只能保障單個服務的一次處理具備原子性、隔離性、一致 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...