• 如何求一个文件的行数?


    第一种方法

    思路:将文件中的字符一个一个读出,然后与 \n 作比较。

       1:  #include <stdio.h>
       2:  #include <string.h>
       3:  #include <errno.h>
       4:   
       5:   
       6:  int main(int argc, char *argv[])
       7:  {
       8:      FILE *fp;
       9:      int n = 0;
      10:      int ch;
      11:   
      12:      if((fp = fopen(argv[1],"r+")) == NULL)
      13:      {
      14:          fprintf(stderr,"open file 1.c error! %s\n",strerror(errno));
      15:      }
      16:   
      17:      while((ch = fgetc(fp)) != EOF)
      18:      {
      19:          if(ch == '\n')
      20:          {
      21:              n++;
      22:          }
      23:      }
      24:   
      25:      fclose(fp);
      26:      printf("%d\n",n);
      27:      return 0;
      28:  }
     
     
    image
     
     

    第二种方法

     
    利用fgets。fgets的原型:char *fgets(char *s, int size, FILE *stream);,fgets最多可以读到size-1个字符,剩下的一个是给 \0 预留的,即总要给 \0 预留一位。
    同时还应注意:fgets遇到 \n 时就停止本次读取,如果数组中可以放下 \n 那么就读 \n ,否则只能下一次读取了,但是可以肯定的是,如果放到下一次读,那么 \n 肯定是第一个,
    从而造成下次只能读到 \n ,\0会自动加上。剩下的内容还得下下次读。这下就找到规律了!即 \n 总是在 \0 的前一位上。
     
       1:  #include <stdio.h>
       2:  #include <string.h>
       3:  #include <errno.h>
       4:   
       5:   
       6:  int main(int argc, char *argv[])
       7:  {
       8:      FILE *fp;
       9:      int n = 0;
      10:      char buffer[3];
      11:   
      12:      if((fp = fopen(argv[1],"r+")) == NULL)
      13:      {
      14:          fprintf(stderr,"open file 1.c error! %s\n",strerror(errno));
      15:      }
      16:   
      17:      while((fgets(buffer,3,fp)) != NULL)
      18:      {
      19:          if(buffer[strlen(buffer) -1] == '\n')
      20:          {
      21:              n++;
      22:          }
      23:      }
      24:   
      25:      fclose(fp);
      26:      printf("%d\n",n);
      27:      return 0;
      28:  }

    image

  • 相关阅读:
    向MySql中插入中文时出现乱码
    MySql插入记录时判断
    SuperGridControl 使用小技巧
    Winform开发中常见界面的DevExpress处理操作
    mysql优化之索引建立的规则
    App性能优化浅谈
    AndroidManifest具体解释之Application(有图更好懂)
    算法——递归思想解决排列组合问题
    Windows App开发之集合控件与数据绑定
    table行随鼠标变色
  • 原文地址:https://www.cnblogs.com/pengdonglin137/p/2941292.html
Copyright © 2020-2023  润新知