c语言zip函数的用法 zip函数返回类型

C语言如何读取zip文件内容??

zip是压缩后的,你直接读取就是乱码,没有能直接读取的,想读取真实内容,必须先按解压算法解压出来。

专注于为中小企业提供成都网站设计、网站建设、外贸网站建设服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业惠水免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了近千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。

怎么用c语言将.zip文件解压成文件夹

简单一点的 直接调用系统命令

比如system("unzip ___filename___ -d target_path");

这样做 实际就相当于在命令行下敲了这样的一个命令

不过 这个要求系统内 必须安装了unzip这个软件 即支持这个命令

复杂一些的 你可以再网上找一个开源的gzip 很多很好找的 然后看懂代码 调用对应的接口函数

这样做的好处不需要依赖系统环境

压缩问题

利用哈夫曼编码制作压缩软件,内容如下:

#include stdio.h

#include string.h

#include stdlib.h

#include conio.h

struct head

{

unsigned char b; //记录字符在数组中的位置

long count; //字符出现频率(权值)

long parent,lch,rch; //定义哈夫曼树指针变量

char bits[256]; //定义存储哈夫曼编码的数组

}

header[512],tmp;

/*压缩*/

void compress()

{

char filename[255],outputfile[255],buf[512];

unsigned char c;

long i,j,m,n,f;

long min1,pt1,flength,length1,length2;

double div;

FILE *ifp,*ofp;

printf("\t请您输入需要压缩的文件:");

gets(filename);

ifp=fopen(filename,"rb");

if(ifp==NULL)

{

printf("\n\t文件打开失败!\n\n");

return;

}

printf("\t请您输入压缩后的文件名:");

gets(outputfile);

ofp=fopen(strcat(outputfile,".hub"),"wb");

if(ofp==NULL)

{

printf("\n\t压缩文件失败!\n\n");

return;

}

flength=0;

while(!feof(ifp))

{

fread(c,1,1,ifp);

header[c].count++; //字符重复出现频率+1

flength++; //字符出现原文件长度+1

}

flength--;

length1=flength; //原文件长度用作求压缩率的分母

header[c].count--;

for(i=0;i512;i++)

{

if(header[i].count!=0) header[i].b=(unsigned char)i;

/*将每个哈夫曼码值及其对应的ASCII码存放在一维数组header[i]中,

且编码表中的下标和ASCII码满足顺序存放关系*/

else header[i].b=0;

header[i].parent=-1;header[i].lch=header[i].rch=-1; //对结点进行初始化

}

for(i=0;i256;i++) //根据频率(权值)大小,对结点进行排序,选择较小的结点进树

{

for(j=i+1;j256;j++)

{

if(header[i].countheader[j].count)

{

tmp=header[i];

header[i]=header[j];

header[j]=tmp;

}

}

}

for(i=0;i256;i++) if(header[i].count==0) break;

n=i; //外部叶子结点数为n个时,内部结点数为n-1,整个哈夫曼树的需要的结点数为2*n-1.

m=2*n-1;

for(i=n;im;i++) //构建哈夫曼树

{

min1=999999999; //预设的最大权值,即结点出现的最大次数

for(j=0;ji;j++)

{

if(header[j].parent!=-1) continue;

//parent!=-1说明该结点已存在哈夫曼树中,跳出循环重新选择新结点*/

if(min1header[j].count)

{

pt1=j;

min1=header[j].count;

continue;

}

}

header[i].count=header[pt1].count;

header[pt1].parent=i; //依据parent域值(结点层数)确定树中结点之间的关系

header[i].lch=pt1; //计算左分支权值大小

min1=999999999;

for(j=0;ji;j++)

{

if(header[j].parent!=-1) continue;

if(min1header[j].count)

{

pt1=j;

min1=header[j].count;

continue;

}

}

header[i].count+=header[pt1].count;

header[i].rch=pt1; //计算右分支权值大小

header[pt1].parent=i;

}

for(i=0;in;i++) //哈夫曼无重复前缀编码

{

f=i;

header[i].bits[0]=0; //根结点编码0

while(header[f].parent!=-1)

{

j=f;

f=header[f].parent;

if(header[f].lch==j) //置左分支编码0

{

j=strlen(header[i].bits);

memmove(header[i].bits+1,header[i].bits,j+1);

//依次存储连接“0”“1”编码

header[i].bits[0]='0';

}

else //置右分支编码1

{

j=strlen(header[i].bits);

memmove(header[i].bits+1,header[i].bits,j+1);

header[i].bits[0]='1';

}

}

}

fseek(ifp,0,SEEK_SET); //从文件开始位置向前移动0字节,即定位到文件开始位置

fwrite(flength,sizeof(int),1,ofp);

/*用来将数据写入文件流中,参数flength指向欲写入的数据地址,

总共写入的字符数以参数size*int来决定,返回实际写入的int数目1*/

fseek(ofp,8,SEEK_SET);

buf[0]=0; //定义缓冲区,它的二进制表示00000000

f=0;

pt1=8;

/*假设原文件第一个字符是"A",8位2进制为01000001,编码后为0110识别编码第一个'0',

那么我们就可以将其左移一位,看起来没什么变化。下一个是'1',应该|1,结果00000001

同理4位都做完,应该是00000110,由于字节中的8位并没有全部用完,我们应该继续读下一个字符,

根据编码表继续拼完剩下的4位,如果字符的编码不足4位,还要继续读一个字符,

如果字符编码超过4位,那么我们将把剩下的位信息拼接到一个新的字节里*/

while(!feof(ifp))

{

c=fgetc(ifp);

f++;

for(i=0;in;i++)

{

if(c==header[i].b) break;

}

strcat(buf,header[i].bits);

j=strlen(buf);

c=0;

while(j=8) //对哈夫曼编码位操作进行压缩存储

{

for(i=0;i8;i++)

{

if(buf[i]=='1') c=(c1)|1;

else c=c1;

}

fwrite(c,1,1,ofp);

pt1++; //统计压缩后文件的长度

strcpy(buf,buf+8); //一个字节一个字节拼接

j=strlen(buf);

}

if(f==flength) break;

}

if(j0) //对哈夫曼编码位操作进行压缩存储

{

strcat(buf,"00000000");

for(i=0;i8;i++)

{

if(buf[i]=='1') c=(c1)|1;

else c=c1;

}

fwrite(c,1,1,ofp);

pt1++;

}

fseek(ofp,4,SEEK_SET);

fwrite(pt1,sizeof(long),1,ofp);

fseek(ofp,pt1,SEEK_SET);

fwrite(n,sizeof(long),1,ofp);

for(i=0;in;i++)

{

fwrite((header[i].b),1,1,ofp);

c=strlen(header[i].bits);

fwrite(c,1,1,ofp);

j=strlen(header[i].bits);

if(j%8!=0) //若存储的位数不是8的倍数,则补0

{

for(f=j%8;f8;f++)

strcat(header[i].bits,"0");

}

while(header[i].bits[0]!=0)

{

c=0;

for(j=0;j8;j++) //字符的有效存储不超过8位,则对有效位数左移实现两字符编码的连接

{

if(header[i].bits[j]=='1') c=(c1)|1; //|1不改变原位置上的“0”“1”值

else c=c1;

}

strcpy(header[i].bits,header[i].bits+8); //把字符的编码按原先存储顺序连接

fwrite(c,1,1,ofp);

}

}

length2=pt1--;

div=((double)length1-(double)length2)/(double)length1; //计算文件的压缩率

fclose(ifp);

fclose(ofp);

printf("\n\t压缩文件成功!\n");

printf("\t压缩率为 %f%%\n\n",div*100);

return;

}

/*解压缩*/

void uncompress()

{

char filename[255],outputfile[255],buf[255],bx[255];

unsigned char c;

long i,j,m,n,f,p,l;

long flength;

FILE *ifp,*ofp;

printf("\t请您输入需要解压缩的文件:");

gets(filename);

ifp=fopen(strcat(filename,".hub"),"rb");

if(ifp==NULL)

{

printf("\n\t文件打开失败!\n");

return;

}

printf("\t请您输入解压缩后的文件名:");

gets(outputfile);

ofp=fopen(outputfile,"wb");

if(ofp==NULL)

{

printf("\n\t解压缩文件失败!\n");

return;

}

fread(flength,sizeof(long),1,ifp); //读取原文件长度,对文件进行定位

fread(f,sizeof(long),1,ifp);

fseek(ifp,f,SEEK_SET);

fread(n,sizeof(long),1,ifp);

for(i=0;in;i++)

{

fread(header[i].b,1,1,ifp);

fread(c,1,1,ifp);

p=(long)c; //读取原文件字符的权值

header[i].count=p;

header[i].bits[0]=0;

if(p%80) m=p/8+1;

else m=p/8;

for(j=0;jm;j++)

{

fread(c,1,1,ifp);

f=c;

itoa(f,buf,2); //将f转换为二进制表示的字符串

f=strlen(buf);

for(l=8;lf;l--)

{

strcat(header[i].bits,"0");

}

strcat(header[i].bits,buf);

}

header[i].bits[p]=0;

}

for(i=0;in;i++) //根据哈夫曼编码的长短,对结点进行排序

{

for(j=i+1;jn;j++)

{

if(strlen(header[i].bits)strlen(header[j].bits))

{

tmp=header[i];

header[i]=header[j];

header[j]=tmp;

}

}

}

p=strlen(header[n-1].bits);

fseek(ifp,8,SEEK_SET);

m=0;

bx[0]=0;

while(1) //通过哈夫曼编码的长短,依次解码,从原来的位存储还原到字节存储

{

while(strlen(bx)(unsigned int)p)

{

fread(c,1,1,ifp);

f=c;

itoa(f,buf,2);

f=strlen(buf);

for(l=8;lf;l--) //在单字节内对相应位置补0

{

strcat(bx,"0");

}

strcat(bx,buf);

}

for(i=0;in;i++)

{

if(memcmp(header[i].bits,bx,header[i].count)==0) break;

}

strcpy(bx,bx+header[i].count); /*从压缩文件中的按位存储还原到按字节存储字符,

字符位置不改变*/

c=header[i].b;

fwrite(c,1,1,ofp);

m++; //统计解压缩后文件的长度

if(m==flength) break; //flength是原文件长度

}

fclose(ifp);

fclose(ofp);

printf("\n\t解压缩文件成功!\n");

if(m==flength) //对解压缩后文件和原文件相同性比较进行判断(根据文件大小)

printf("\t解压缩文件与原文件相同!\n\n");

else printf("\t解压缩文件与原文件不同!\n\n");

return;

}

/*主函数*/

int main()

{

int c;

while(1) //菜单工具栏

{

printf("\t _______________________________________________\n");

printf("\n");

printf("\t * 压缩、解压缩 小工具 * \n");

printf("\t _______________________________________________\n");

printf("\t _______________________________________________\n");

printf("\t| |\n");

printf("\t| 1.压缩 |\n");

printf("\t| 2.解压缩 |\n");

printf("\t| 0.退出 |\n");

printf("\t|_______________________________________________|\n");

printf("\n");

printf("\t 说明:(1)采用哈夫曼编码\n");

printf("\t (2)适用于文本文件\n");

printf("\n");

do //对用户输入进行容错处理

{

printf("\n\t*请选择相应功能(0-2):");

c=getch();

printf("%c\n",c);

if(c!='0' c!='1' c!='2')

{

printf("\t@_@请检查您的输入在0~2之间!\n");

printf("\t请再输入一遍!\n");

}

}while(c!='0' c!='1' c!='2');

if(c=='1') compress(); //调用压缩子函数

else if(c=='2') uncompress(); //调用解压缩子函数

else

{

printf("\t欢迎您再次使用该工具^_^\n");

exit(0); //退出该工具

}

system("pause"); //任意键继续

system("cls"); //清屏

}

return 0;

}

python zip函数的用法

定义:zip([iterable, ...])

zip()是Python的一个内建函数,它接受一系列可迭代的对象作为参数,将对象中对应的元素打包成一个个tuple(元组),然后返回由这些 tuples组成的list(列表)。若传入参数的长度不等,则返回list的长度和参数中长度最短的对象相同。利用*号操作符,可以将list unzip(解压),看下面的例子就明白了:

1 2 3 4 5 6 7 8 9

a = [1,2,3] b = [4,5,6] c = [4,5,6,7,8] zipped = zip(a,b) [(1, 4), (2, 5), (3, 6)] zip(a,c) [(1, 4), (2, 5), (3, 6)] zip(*zipped) [(1, 2, 3), (4, 5, 6)]

对于这个并不是很常用函数,下面举几个例子说明它的用法:

* 二维矩阵变换(矩阵的行列互换)

比如我们有一个由列表描述的二维矩阵

a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]

通过python列表推导的方法,我们也能轻易完成这个任务

1 2

print [ [row[col] for row in a] for col in range(len(a[0]))] [[1, 4, 7], [2, 5, 8], [3, 6, 9]]

另外一种让人困惑的方法就是利用zip函数:

1 2 3 4 5

a = [[1, 2, 3], [4, 5, 6], [7, 8, 9]] zip(*a) [(1, 4, 7), (2, 5, 8), (3, 6, 9)] map(list,zip(*a)) [[1, 4, 7], [2, 5, 8], [3, 6, 9]]

这种方法速度更快但也更难以理解,将list看成tuple解压,恰好得到我们“行列互换”的效果,再通过对每个元素应用list()函数,将tuple转换为list

* 以指定概率获取元素

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27

import random def random_pick(seq,probabilities): x = random.uniform(0, 1) cumulative_probability = 0.0 for item, item_probability in zip(seq, probabilities): cumulative_probability += item_probability if x cumulative_probability: break return item for i in range(15): random_pick("abc",[0.1,0.3,0.6]) 'c' 'b' 'c' 'c' 'a' 'b' 'c' 'c' 'c' 'a' 'b' 'b' 'c' 'a' 'c'

这个函数有个限制,指定概率的列表必须和元素一一对应,而且和为1,否则这个函数可能不能像预想的那样工作。

稍微解释下,先利用random.uniform()函数生成一个0-1之间的随机数并复制给x,利用zip()函数将元素和他对应的概率打包成tuple,然后将每个元素的概率进行叠加,直到和大于x终止循环

这样,”a”被选中的概率就是x取值位于0-0.1的概率,同理”b”为0.1-0.4,”c”为0.4-1.0,假设x是在0-1之间平均取值的,显然我们的目的已经达到

能列举些C语言中比较常见重要库函数的用法吗?

我的建议是去看MSDN,里面有详细的库函数的说明和使用方法。C的库函数有很多,一条条说不现实,就是一个专业的程序员也不可能将库函数都记下来。我从网上搜了点库函数的用法,你看看吧。还是那句话,想了解库函数,还是看MSDN。

下面也是我从网上找到的。网上这种东西很多。但我认为要是真正精通,还是MSDN

文件的打开(fopen函数)

fopen函数用来打开一个文件,其调用的一般形式为:

文件指针名=fopen(文件名,使用文件方式);

其中,

“文件指针名”必须是被说明为FILE 类型的指针变量;

“文件名”是被打开文件的文件名;

“使用文件方式”是指文件的类型和操作要求。

“文件名”是字符串常量或字符串数组。

例如:

FILE *fp;

fp=("file a","r");

其意义是在当前目录下打开文件file a,只允许进行“读”操作,并使fp指向该文件。

又如:

FILE *fphzk

fphzk=("c:\\hzk16","rb")

其意义是打开C驱动器磁盘的根目录下的文件hzk16,这是一个二进制文件,只允许按二进制方式进行读操作。两个反斜线“\\ ”中的第一个表示转义字符,第二个表示根目录。

使用文件的方式共有12种,下面给出了它们的符号和意义。

文件使用方式

意义

“rt”

只读打开一个文本文件,只允许读数据

“wt”

只写打开或建立一个文本文件,只允许写数据

“at”

追加打开一个文本文件,并在文件末尾写数据

“rb”

只读打开一个二进制文件,只允许读数据

“wb”

只写打开或建立一个二进制文件,只允许写数据

“ab”

追加打开一个二进制文件,并在文件末尾写数据

“rt+”

读写打开一个文本文件,允许读和写

“wt+”

读写打开或建立一个文本文件,允许读写

“at+”

读写打开一个文本文件,允许读,或在文件末追加数据

“rb+”

读写打开一个二进制文件,允许读和写

“wb+”

读写打开或建立一个二进制文件,允许读和写

“ab+”

读写打开一个二进制文件,允许读,或在文件末追加数据

对于文件使用方式有以下几点说明:

1) 文件使用方式由r,w,a,t,b,+六个字符拼成,各字符的含义是:

r(read): 读

w(write): 写

a(append): 追加

t(text): 文本文件,可省略不写

b(banary): 二进制文件

+: 读和写

2) 凡用“r”打开一个文件时,该文件必须已经存在,且只能从该文件读出。

3) 用“w”打开的文件只能向该文件写入。若打开的文件不存在,则以指定的文件名建立该文件,若打开的文件已经存在,则将该文件删去,重建一个新文件。

4) 若要向一个已存在的文件追加新的信息,只能用“a”方式打开文件。但此时该文件必须是存在的,否则将会出错。

5) 在打开一个文件时,如果出错,fopen将返回一个空指针值NULL。在程序中可以用这一信息来判别是否完成打开文件的工作,并作相应的处理。因此常用以下程序段打开文件:

6) if((fp=fopen("c:\\hzk16","rb")==NULL)

{

printf("\nerror on open c:\\hzk16 file!");

getch();

exit(1);

}

这段程序的意义是,如果返回的指针为空,表示不能打开C盘根目录下的hzk16文件,则给出提示信息“error on open c:\ hzk16 file!”,下一行getch()的功能是从键盘输入一个字符,但不在屏幕上显示。在这里,该行的作用是等待,只有当用户从键盘敲任一键时,程序才继续执行,因此用户可利用这个等待时间阅读出错提示。敲键后执行exit(1)退出程序。

7) 把一个文本文件读入内存时,要将ASCII码转换成二进制码,而把文件以文本方式写入磁盘时,也要把二进制码转换成ASCII码,因此文本文件的读写要花费较多的转换时间。对二进制文件的读写不存在这种转换。

8) 标准输入文件(键盘),标准输出文件(显示器),标准出错输出(出错信息)是由系统打开的,可直接使用。

13.3.2 文件关闭函数(fclose函数)

文件一旦使用完毕,应用关闭文件函数把文件关闭,以避免文件的数据丢失等错误。

fclose函数调用的一般形式是:

fclose(文件指针);

例如:

fclose(fp);

正常完成关闭文件操作时,fclose函数返回值为0。如返回非零值则表示有错误发生。

13.4 文件的读写

对文件的读和写是最常用的文件操作。在C语言中提供了多种文件读写的函数:

·字符读写函数 :fgetc和fputc

·字符串读写函数:fgets和fputs

·数据块读写函数:freed和fwrite

·格式化读写函数:fscanf和fprinf

下面分别予以介绍。使用以上函数都要求包含头文件stdio.h。

13.4.1 字符读写函数fgetc和fputc

字符读写函数是以字符(字节)为单位的读写函数。每次可从文件读出或向文件写入一个字符。

1. 读字符函数fgetc

fgetc函数的功能是从指定的文件中读一个字符,函数调用的形式为:

字符变量=fgetc(文件指针);

例如:

ch=fgetc(fp);

其意义是从打开的文件fp中读取一个字符并送入ch中。

对于fgetc函数的使用有以下几点说明:

1) 在fgetc函数调用中,读取的文件必须是以读或读写方式打开的。

2) 读取字符的结果也可以不向字符变量赋值,

例如:

fgetc(fp);

但是读出的字符不能保存。

3) 在文件内部有一个位置指针。用来指向文件的当前读写字节。在文件打开时,该指针总是指向文件的第一个字节。使用fgetc 函数后,该位置指针将向后移动一个字节。 因此可连续多次使用fgetc函数,读取多个字符。应注意文件指针和文件内部的位置指针不是一回事。文件指针是指向整个文件的,须在程序中定义说明,只要不重新赋值,文件指针的值是不变的。文件内部的位置指针用以指示文件内部的当前读写位置,每读写一次,该指针均向后移动,它不需在程序中定义说明,而是由系统自动设置的。

【例13.1】读入文件c1.doc,在屏幕上输出。

#includestdio.h

main()

{

FILE *fp;

char ch;

if((fp=fopen("d:\\jrzh\\example\\c1.txt","rt"))==NULL)

{

printf("\nCannot open file strike any key exit!");

getch();

exit(1);

}

ch=fgetc(fp);

while(ch!=EOF)

{

putchar(ch);

ch=fgetc(fp);

}

fclose(fp);

}

本例程序的功能是从文件中逐个读取字符,在屏幕上显示。程序定义了文件指针fp,以读文本文件方式打开文件“d:\\jrzh\\example\\ex1_1.c”,并使fp指向该文件。如打开文件出错,给出提示并退出程序。程序第12行先读出一个字符,然后进入循环,只要读出的字符不是文件结束标志(每个文件末有一结束标志EOF)就把该字符显示在屏幕上,再读入下一字符。每读一次,文件内部的位置指针向后移动一个字符,文件结束时,该指针指向EOF。执行本程序将显示整个文件。

2. 写字符函数fputc

fputc函数的功能是把一个字符写入指定的文件中,函数调用的形式为:

fputc(字符量,文件指针);

其中,待写入的字符量可以是字符常量或变量,例如:

fputc('a',fp);

其意义是把字符a写入fp所指向的文件中。

对于fputc函数的使用也要说明几点:

1) 被写入的文件可以用写、读写、追加方式打开,用写或读写方式打开一个已存在的文件时将清除原有的文件内容,写入字符从文件首开始。如需保留原有文件内容,希望写入的字符以文件末开始存放,必须以追加方式打开文件。被写入的文件若不存在,则创建该文件。

2) 每写入一个字符,文件内部位置指针向后移动一个字节。

3) fputc函数有一个返回值,如写入成功则返回写入的字符,否则返回一个EOF。可用此来判断写入是否成功。

【例13.2】从键盘输入一行字符,写入一个文件,再把该文件内容读出显示在屏幕上。

#includestdio.h

main()

{

FILE *fp;

char ch;

if((fp=fopen("d:\\jrzh\\example\\string","wt+"))==NULL)

{

printf("Cannot open file strike any key exit!");

getch();

exit(1);

}

printf("input a string:\n");

ch=getchar();

while (ch!='\n')

{

fputc(ch,fp);

ch=getchar();

}

rewind(fp);

ch=fgetc(fp);

while(ch!=EOF)

{

putchar(ch);

ch=fgetc(fp);

}

printf("\n");

fclose(fp);

}

程序中第6行以读写文本文件方式打开文件string。程序第13行从键盘读入一个字符后进入循环,当读入字符不为回车符时,则把该字符写入文件之中,然后继续从键盘读入下一字符。每输入一个字符,文件内部位置指针向后移动一个字节。写入完毕,该指针已指向文件末。如要把文件从头读出,须把指针移向文件头,程序第19行rewind函数用于把fp所指文件的内部位置指针移到文件头。第20至25行用于读出文件中的一行内容。

【例13.3】把命令行参数中的前一个文件名标识的文件,复制到后一个文件名标识的文件中,如命令行中只有一个文件名则把该文件写到标准输出文件(显示器)中。

#includestdio.h

main(int argc,char *argv[])

{

FILE *fp1,*fp2;

char ch;

if(argc==1)

{

printf("have not enter file name strike any key exit");

getch();

exit(0);

}

if((fp1=fopen(argv[1],"rt"))==NULL)

{

printf("Cannot open %s\n",argv[1]);

getch();

exit(1);

}

if(argc==2) fp2=stdout;

else if((fp2=fopen(argv[2],"wt+"))==NULL)

{

printf("Cannot open %s\n",argv[1]);

getch();

exit(1);

}

while((ch=fgetc(fp1))!=EOF)

fputc(ch,fp2);

fclose(fp1);

fclose(fp2);

}

本程序为带参的main函数。程序中定义了两个文件指针fp1和fp2,分别指向命令行参数中给出的文件。如命令行参数中没有给出文件名,则给出提示信息。程序第18行表示如果只给出一个文件名,则使fp2指向标准输出文件(即显示器)。程序第25行至28行用循环语句逐个读出文件1中的字符再送到文件2中。再次运行时,给出了一个文件名,故输出给标准输出文件stdout,即在显示器上显示文件内容。第三次运行,给出了二个文件名,因此把string中的内容读出,写入到OK之中。可用DOS命令type显示OK的内容。

13.4.2 字符串读写函数fgets和fputs

1. 读字符串函数fgets

函数的功能是从指定的文件中读一个字符串到字符数组中,函数调用的形式为:

fgets(字符数组名,n,文件指针);

其中的n是一个正整数。表示从文件中读出的字符串不超过 n-1个字符。在读入的最后一个字符后加上串结束标志'\0'。

例如:

fgets(str,n,fp);

的意义是从fp所指的文件中读出n-1个字符送入字符数组str中。

【例13.4】从string文件中读入一个含10个字符的字符串。

#includestdio.h

main()

{

FILE *fp;

char str[11];

if((fp=fopen("d:\\jrzh\\example\\string","rt"))==NULL)

{

printf("\nCannot open file strike any key exit!");

getch();

exit(1);

}

fgets(str,11,fp);

printf("\n%s\n",str);

fclose(fp);

}

本例定义了一个字符数组str共11个字节,在以读文本文件方式打开文件string后,从中读出10个字符送入str数组,在数组最后一个单元内将加上'\0',然后在屏幕上显示输出str数组。输出的十个字符正是例13.1程序的前十个字符。

对fgets函数有两点说明:

1) 在读出n-1个字符之前,如遇到了换行符或EOF,则读出结束。

2) fgets函数也有返回值,其返回值是字符数组的首地址。

2. 写字符串函数fputs

fputs函数的功能是向指定的文件写入一个字符串,其调用形式为:

fputs(字符串,文件指针);

其中字符串可以是字符串常量,也可以是字符数组名,或指针变量,例如:

fputs(“abcd“,fp);

其意义是把字符串“abcd”写入fp所指的文件之中。

【例13.5】在例13.2中建立的文件string中追加一个字符串。

#includestdio.h

main()

{

FILE *fp;

char ch,st[20];

if((fp=fopen("string","at+"))==NULL)

{

printf("Cannot open file strike any key exit!");

getch();

exit(1);

}

printf("input a string:\n");

scanf("%s",st);

fputs(st,fp);

rewind(fp);

ch=fgetc(fp);

while(ch!=EOF)

{

putchar(ch);

ch=fgetc(fp);

}

printf("\n");

fclose(fp);

}

本例要求在string文件末加写字符串,因此,在程序第6行以追加读写文本文件的方式打开文件string。然后输入字符串,并用fputs函数把该串写入文件string。在程序15行用rewind函数把文件内部位置指针移到文件首。再进入循环逐个显示当前文件中的全部内容。

13.4.3 数据块读写函数fread和fwtrite

C语言还提供了用于整块数据的读写函数。可用来读写一组数据,如一个数组元素,一个结构变量的值等。

读数据块函数调用的一般形式为:

fread(buffer,size,count,fp);

写数据块函数调用的一般形式为:

fwrite(buffer,size,count,fp);

其中:

buffer 是一个指针,在fread函数中,它表示存放输入数据的首地址。在fwrite函数中,它表示存放输出数据的首地址。

size 表示数据块的字节数。

count 表示要读写的数据块块数。

fp 表示文件指针。

例如:

fread(fa,4,5,fp);

其意义是从fp所指的文件中,每次读4个字节(一个实数)送入实数组fa中,连续读5次,即读5个实数到fa中。

【例13.6】从键盘输入两个学生数据,写入一个文件中,再读出这两个学生的数据显示在屏幕上。

#includestdio.h

struct stu

{

char name[10];

int num;

int age;

char addr[15];

}boya[2],boyb[2],*pp,*qq;

main()

{

FILE *fp;

char ch;

int i;

pp=boya;

qq=boyb;

if((fp=fopen("d:\\jrzh\\example\\stu_list","wb+"))==NULL)

{

printf("Cannot open file strike any key exit!");

getch();

exit(1);

}

printf("\ninput data\n");

for(i=0;i2;i++,pp++)

scanf("%s%d%d%s",pp-name,pp-num,pp-age,pp-addr);

pp=boya;

fwrite(pp,sizeof(struct stu),2,fp);

rewind(fp);

fread(qq,sizeof(struct stu),2,fp);

printf("\n\nname\tnumber age addr\n");

for(i=0;i2;i++,qq++)

printf("%s\t%5d%7d %s\n",qq-name,qq-num,qq-age,qq-addr);

fclose(fp);

}

本例程序定义了一个结构stu,说明了两个结构数组boya和boyb以及两个结构指针变量pp和qq。pp指向boya,qq指向boyb。程序第16行以读写方式打开二进制文件“stu_list”,输入二个学生数据之后,写入该文件中,然后把文件内部位置指针移到文件首,读出两块学生数据后,在屏幕上显示。

------

回复此文章 |

回复主题:Re:c语言文件操作 | 作者: haohao | 军衔:六级军士 | 发表时间:2004-07-28 11:08:47

下午应该把这个搞定了.

------

回复此文章 |

回复主题:Re:Re:c语言文件操作 | 作者: haohao | 军衔:六级军士 | 发表时间:2004-07-28 11:10:23

13.7 C库文件

C系统提供了丰富的系统文件,称为库文件,C的库文件分为两类,一类是扩展名为".h"的文件,称为头文件,在前面的包含命令中我们已多次使用过。在".h"文件中包含了常量定义、类型定义、宏定义、函数原型以及各种编译选择设置等信息。另一类是函数库,包括了各种函数的目标代码,供用户在程序中调用。 通常在程序中调用一个库函数时,要在调用之前包含该函数原型所在的".h" 文件。

下面给出Turbo C的全部".h"文件。

Turbo C头文件

n ALLOC.H 说明内存管理函数(分配、释放等)。

n ASSERT.H 定义 assert调试宏。

n BIOS.H 说明调用IBM—PC ROM BIOS子程序的各个函数。

n CONIO.H 说明调用DOS控制台I/O子程序的各个函数。

n CTYPE.H 包含有关字符分类及转换的名类信息(如 isalpha和toascii等)。

n DIR.H 包含有关目录和路径的结构、宏定义和函数。

n DOS.H 定义和说明MSDOS和8086调用的一些常量和函数。

n ERRON.H 定义错误代码的助记符。

n FCNTL.H 定义在与open库子程序连接时的符号常量。

n FLOAT.H 包含有关浮点运算的一些参数和函数。

n GRAPHICS.H 说明有关图形功能的各个函数,图形错误代码的常量定义,正对不同驱动程序的各种颜色值,及函数用到的一些特殊结构。

n IO.H 包含低级I/O子程序的结构和说明。

n LIMIT.H 包含各环境参数、编译时间限制、数的范围等信息。

n MATH.H 说明数学运算函数,还定了 HUGE VAL 宏, 说明了matherr和matherr子程序用到的特殊结构。

n MEM.H 说明一些内存操作函数(其中大多数也在STRING.H中说明)。

n PROCESS.H 说明进程管理的各个函数,spawn…和EXEC …函数的结构说明。

n SETJMP.H 定义longjmp和setjmp函数用到的jmp buf类型,说明这两个函数。

n SHARE.H 定义文件共享函数的参数。

n SIGNAL.H 定义SIG[ZZ(Z] [ZZ)]IGN和SIG[ZZ(Z] [ZZ)]DFL常量,说明rajse和signal两个函数。

n STDARG.H 定义读函数参数表的宏。(如vprintf,vscarf函数)。

n STDDEF.H 定义一些公共数据类型和宏。

n STDIO.H 定义Kernighan和Ritchie在Unix System V 中定义的标准和扩展的类型和宏。还定义标准I/O 预定义流:stdin,stdout和stderr,说明 I/O流子程序。

n STDLIB.H 说明一些常用的子程序:转换子程序、搜索/ 排序子程序等。

n STRING.H 说明一些串操作和内存操作函数。

n SYS\STAT.H 定义在打开和创建文件时用到的一些符号常量。

n SYS\TYPES.H 说明ftime函数和timeb结构。

n SYS\TIME.H 定义时间的类型time[ZZ(Z] [ZZ)]t。

n TIME.H 定义时间转换子程序asctime、localtime和gmtime的结构,ctime、 difftime、 gmtime、 localtime和stime用到的类型,并提供这些函数的原型。

n VALUE.H 定义一些重要常量,包括依赖于机器硬件的和为与Unix System V相兼容而说明的一些常量,包括浮点和双精度值的范围。

13.8 本章小结

1. C系统把文件当作一个“流”,按字节进行处理。

2. C文件按编码方式分为二进制文件和ASCII文件。

3. C语言中,用文件指针标识文件,当一个文件被打开时,可取得该文件指针。

4. 文件在读写之前必须打开,读写结束必须关闭。

5. 文件可按只读、只写、读写、追加四种操作方式打开,同时还必须指定文件的类型是二进制文件还是文本文件。

6. 文件可按字节,字符串,数据块为单位读写,文件也可按指定的格式进行读写。

7. 文件内部的位置指针可指示当前的读写位置,移动该指针可以对文件实现随机读写。


名称栏目:c语言zip函数的用法 zip函数返回类型
本文来源:http://ybzwz.com/article/dodeoij.html