linux 读取一行,linux 查看文件命令

大家好,如果您还对linux 读取一行不太了解,没有关系,今天就由本站为大家分享linux 读取一行的知识,包括linux 查看文件命令的问题都会给大家分析到,还望可以解决大家的问题,下面我们就开始吧!

c语言逐行读取文件

可以使用fgets函数。

1函数名:

fgets

2声明:

char*fgets(char*buf, int bufsize, FILE*stream);

3头文件:

stdio.h

4功能:

从文件结构体指针stream中读取数据,每次读取一行。读取的数据保存在buf指向的字符数组中,每次最多读取bufsize-1个字符(第bufsize个字符赋'\0'),如果文件中的该行,不足bufsize个字符,则读完该行就结束。如若该行(包括最后一个换行符)的字符数超过bufsize-1,则fgets只返回一个不完整的行,但是,缓冲区总是以NULL字符结尾,对fgets的下一次调用会继续读该行。函数成功将返回buf,失败或读到文件结尾返回NULL。因此我们不能直接通过fgets的返回值来判断函数是否是出错而终止的,应该借助feof函数或者ferror函数来判断。

5参数:

*buf:字符型指针,指向用来存储所得数据的地址。

bufsize:整型数据,指明存储数据的大小。

*stream:文件结构体指针,将要读取的文件流。

6返回值:

成功,则返回第一个参数buf;

在读字符时遇到end-of-file(文件结尾),则eof指示器被设置,如果还没读入任何字符就遇到这种情况,则buf保持原来的内容,返回NULL;

如果发生读入错误,error指示器被设置,返回NULL,buf的值可能被改变。

7示例代码:

逐行读取in.txt中的数据,并打印。每行不超过100个字符。

intmain()

{

FILE*fp;

charbuf[101];

fp=fopen("in.txt","r");//打开文件

while(fgets(buf,sizeof(buf),fp))//每次读取一行数据,直到读取失败。

{

printf("%s\n",buf);//打印该行。

}

fclose(fp);//关闭文件。

return0;

}

c语言中清除一行的命令

在 C语言中,有一种特殊的控制字符叫做退格符'\b',它可以将光标移动回前一个位置从而覆盖前面的字符。因此,可以使用循环打印退格符来清除一行的内容。以下是一个示例代码:

Copy code

//输出一行文本

printf("abcdef");

printf("123321456789");

//使用退格符清除 123321456789

for(int i= 0; i< 12; i++){

printf("\b\b");

}

输出结果为:

Copy code

abcdef// 123321456789已被清除掉,abcdef保留了下来

在上述代码中,我们先打印了两行文本,然后使用循环打印了 12个退格符,这样就将前一行的内容全部清除掉了。需要注意的是,退格符只能将光标向前移动一个位置,因此需要打印足够多的退格符才能将整行内容全部清除。

linux下开发脚本搜索子目录批量更改文件名

前言

本文主要给大家介绍了关于Linux shell用sed批量更改文件名的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

示例

去除特定字符

目标:将 2017-01-01.jpg、2018-01-01.jpg改为 20170101.jpg、20180101.jpg

方法:将所有-替换为空

for file in `ls| grep.jpg`

do

newfile=`echo$file| sed's/-//g'`

mv$file$newfile

done

这里使用sed进行标准输出的字符串替换,其通用格式如下:

stdout| sed's/pattern/replace/'

上述示例中,在末尾添加g用于替换所有匹配项,而不仅仅替换第一个匹配项。

中间插入字符

目标:将 book01.txt、paper02.txt改为 book-01.txt、paper-02.txt

方法:用分组匹配分别获取待插入位置两侧的字符串,再通过反向引用实现替换

for file in `ls| grep.txt`

do

newfile=`echo$file| sed's/\([a-z]\+\)\([0-9]\+\)/\1-\2/'`

mv$file$newfile

done

分析

上述示例首先通过 ls和 grep命令得到待改名的文件列表,然后用 sed命令进行字符串的替换,最后再使用 mv命令来完成文件名的更改。

获取待改名文件列表的方法有很多,可以通过 find命令,也可以直接给出字符串,我们将在下文中提到。

注意 for循环后面的 ls| grep.txt,这条命令用两个反单引号括了起来,与$(ls| grep.txt)的作用相同,被包围的字符串会被当作命令执行,然后返回字符串结果。

文件名包含空格的解决方法

我们可以直接将文件列表写到 for循环中,而不是通过命令来得到,例如:

for file in"file1 file2 file3"

do

...

done

可以看到 for循环是通过空格来分割字符串,因此如果待更改的文件名中包含空格的话,就会被拆分成多个文件名,从而出错。

要解决这个问题,我们可以将 IFS(内部字段分隔符)设置为换行符\n,这样一来,for循环就会按行来获取变量的值,确保每次获取的确实是一个完整的文件名。

设置 IFS变量的命令需要放在 for循环之前:

IFS=$'\n'

for file in `ls`

do

...

done

也可以直接使用 while read命令一次读取一行到变量 file中:

ls| grep"*.txt"| while read file

do

...

done

使用 find获取文件列表

之前的示例中,我们是通过 ls命令来获取文件列表。该命令只能获取某个目录的文件,而且没法进行多种条件的筛选。

而一说到文件的查找,不得不提到功能强大的 find命令。该命令可以在多个层次的目录中查找文件,并能够设定诸如创建时间、文件大小、所有者等多种条件,查找起文件来特别方便灵活。

用 find命令来获取文件列表,再用 sed命令配合正则表达式来修改文件名,这两个命令的结合几乎能完成所有常见的批量改名任务。

例如,将所有大于1M,且后缀为txt或jpg的文件,由形如 book_20170101.txt、image_20170101.jpg的文件改名为 20170101-book.txt、20170101-image.jpg,代码如下:

for file in `find.-size+1M-name"*_*.txt"-o-name"*_*.jpg"`

do

newfile=`echo$file| sed's/\([a-z]\+\)_\([0-9]\+\)./\2-\1./'`

mv$file$newfile

done

阅读剩余
THE END