linux按行读取 空行丢弃

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_39642794/article/details/88855188

我的代码:

代码中遇到以下问题:strlen(app_name)!=0 不能写1 因为虽然如果有一行空行,会读入一行\n 但是上面的那个if  已经把‘\n’改为‘\0’ 

每次读取之后,在开始下一次读取的时候之前必须要把数组清0 因为上一次读取比下一次多 数组因为覆盖不全,会干扰下一次读取。

如果在win建立的文本 拖到linux下面,会出现格式错误。cat -v a.txt 这个能显示乱码

解决办法:yum -y install dos2unix 

                 dos2unix a.txt 

下面是别人的

   在用fgets(..)读入数据时,先定义一个字符数组或字符指针,如果定义了字符指针 ,那么一定要初始化。

        example:

              char s[100]; //可以。

              char *s;  //不可以,因为只是声明了一个指针。但并没有为它分配内存缓冲区。

        所以,如果要用指针,则  char *s=(char *)malloc(100*sizeof(char)); 为其分配内存空间,c++中用char *s=new char [100];      如果为分配内存空间,编译时不会检查出问题,但运行时会出现未知错误。。

        fgets(...)读入文本行时的两种情况。

          1.如果n大于一行的字符串长度,那么当读到字符串末尾的换行符时,fgets(..)会返回。并且在s的最后插入字符串结束标志'\0'。 而s缓冲区剩余的位置不会再填充。

           example:

              123abc

              fgets(s,10,fp);

              此时,读入七个字符,123abc\n,实际上还有最后的'\0',所以,strlen(s)=7; 如果要去除末尾的\n,s[strlen(s)-1]='\0';便可。

          2.如果n小于等于一行的字符串的长度,那么读入n-1个字符,此时并没有读入\n因为并没有到行尾 ,同样在最后会插入'\0'.

          example:

            123abc

            char  s[5];

            fgets(s,5,fp);

            这时读入4个字符,123a,并没有换行符,所以strlen(s)=4.

       fgets(...)读入整个文件内容

          通常用while()循环来使fges()读入文本全部内容,并按行读入。

          

[cpp] view plain copy
char s[1024];  
           while((fgets(s,1024,fp))!=NULL)  
            {  
                  printf(s);  
            }  

         当然如果n小于每行的字符个数,也可以读,只不过读的次数要多。

          假设一行为 : 123456789

          

[cpp] view plain copy
char s[2];  
          int  num=0;  
          while((fgets(s,2,fp))!=NULL)  
            {  
                 printf(s);  
                 n++;  
            }  

          每次读入一个字符, 最后也会读完一行,num=10,读了十次,所以,fgets若没遇到换行符,会接着从前一次的位置继续读入n-1个字符,只要是文本流没关闭。

         读入空行的情况:

            第一行   abcdef123

            第二行                       

            第三行  helloworld

            其中第二行为空,fget(..)会把第二行也读入,因为并未到文件结尾。

            有时我们并不需要空行,可以这样做。

          

[cpp] view plain copy
while((fgets(s,n,fp))!=NULL)  
             {  
                  if(strlen(s)!=1)    //注意这儿是1不是0,因为尽管是空行,它也会读入换行符,strlen(s)=1;  
                      printf(s);  
             }  

         fgets(...)从标准设备读数据。

            用fgets(...)还也读入标准输入设备(一般为键盘)的信息

            原型  :  fgets(s,n,stdin);

            假设在控制台下,我们可以用fgets(...)替代gets(),读入键盘输入的信息,fgets()是安全的,因为不会像gets()有溢出的可能。。

            比如 :输入 abc

            fgets(s,n,stdin)也会读入n-1个字符。但是只是从stdin流读入。。。


写入:

CHAR    log[64];
CHAR compile_time[verstr_max_len];
CHAR app_name[verstr_max_len];
CHAR ver[verstr_max_len];
    FILE    *fp;

    if ( (fp=fopen(TASKD_VRE_FILE, "w")) == 0 )
    {
sprintf(log, "向taskdver.txt文件写入版本信息失败");
MyWriteLog(log,TRUE);
        return -1;
    }
else
{
taskdGetVersionInfo(verstr_max_len,app_name,ver,compile_time);
fputs(app_name,fp);
fputc('\n',fp);

fputs(ver,fp);
fputc('\n',fp);

fputs(compile_time,fp);
fputc('\n',fp);

fclose(fp);/*关闭文件*/
return 0;

}

读取;

FILE    *fp;
if ( (fp=fopen(verfile, "r")) == 0 )
{
return -1;
}
else
{
fgets(app_name,str_max_len,fp);
if(app_name[strlen(app_name)-1] == '\n')
{
app_name[strlen(app_name)-1] = '\0';  /*去掉换行符*/
}

fgets(version,str_max_len,fp);
if(version[strlen(version)-1] == '\n')
{
version[strlen(version)-1] = '\0';  /*去掉换行符*/
}

fgets(compile_time,str_max_len,fp);
if(compile_time[strlen(compile_time)-1] == '\n')
{
compile_time[strlen(compile_time)-1] = '\0';  /*去掉换行符*/
}

fclose(fp);
return 0;
--------------------- 
作者:sweetfather 
来源:CSDN 
原文:https://blog.csdn.net/sweetfather/article/details/79650676 
版权声明:本文为博主原创文章,转载请附上博文链接!

展开阅读全文

没有更多推荐了,返回首页