1 基于C的文件操作 在ANSI C中,对文件的操作分为两种方式,即流式文件操作和I/O文件操作 2 一、流式文件操作 3 4 1.fopen() 5 FILE *fopen(const char *filename,const char *mode) 6 "r" 以只读方式打开文件 7 "w" 以只写方式打开文件 8 "a" 以追加方式打开文件 9 "r+" 以读/写方式打开文件,如无文件出错 10 "w+" 以读/写方式打开文件,如无文件生成新文件 11 12 一个文件可以以文本模式或二进制模式打开,这两种的区别是:在文本模式中回车被当成一个字符‘‘\n‘‘,而二进制模式认为它是两个字符0x0D,0x0A;如果在文件中读到0x1B,文本模式会认为这是文件结束符,也就是二进制模型不会对文件进行处理,而文本方式会按一定的方式对数据作相应的转换。 13 14 系统默认的是以文本模式打开 t b 15 16 13.fread() 17 char x[4230]; 18 fread(x,200,12 ,fp);//共读取200*12=2400个字节 19 20 size_t fread(void *ptr, size_t size, size_t n, FILE *stream); 21 size是每块的字节数;n是读取的块数, 22 如果成功,返回实际读取的块数(不是字节数), 23 本函数一般用于二进制模式打开的文件中。 24 14.fwrite() 25 char x[]="I Love You"; 26 fwire(x, 6,12,fp);//写入6*12=72字节 27 将把"I Love"写到流fp中12次,共72字节 28 29 size_t fwrite(const void *ptr, size_t size, size_t n, FILE *stream); 30 如果成功,返回实际写入的块数(不是字节数),本函数一般用于二进制模式打开的文件中。 31 32 2.fclose() 33 int fclose(FILE *fp);如果成功,返回0,失败返回EOF 34 35 36 3.fputc() 37 fputc(‘‘X‘‘,fp); 38 4.fgetc() 39 char ch1=fgetc(fp); 40 5. fseek() 41 此函数一般用于二进制模式打开的文件中,功能是定位到流中指定的位置 42 int fseek(FILE *stream, long offset, int whence); 43 如果成功返回0,参数offset是移动的字符数,whence是移动的基准,取值是 44 SEEK_SET 0 文件开头 45 SEEK_CUR 1 当前读写的位置 46 SEEK_END 2 文件尾部 47 48 fseek(fp,1234L,SEEK_CUR);//把读写位置从当前位置向后移动1234字节 49 fseek(fp,0L,2);//把读写位置移动到文件尾 50 6.fputs() 51 fputs("I Love You",fp); 52 7.fgets() 53 从流中读一行或指定个字符 54 char *fgets(char *s, int n, FILE *stream); 55 从流中读取n-1个字符,除非读完一行,不包括行尾的‘‘\n‘‘参数s是来接收字符串, 56 如果成功则返回s的指针,否则返回NULL。 57 8.fprintf() 58 fprintf(fp,"%2d%s",4,"Hahaha"); 59 9.fscanf() 60 fscanf(fp,"%d%d" ,&x,&y); 61 10.feof() 62 if(feof(fp)) printf("已到文件尾"); 63 11.ferror() 64 int ferror(FILE *stream); 65 返回流最近的错误代码,可用clearerr()来清除它,void clearerr(FILE *stream); 66 printf("%d",ferror(fp)); 67 12.rewind() 68 把当前的读写位置回到文件开始,相当于fseek(fp,0L,SEEK_SET); 69 rewind(fp); 70 13.remove() 71 删除文件 remove("c:\\io.sys"); 72 73 15.tmpfile() 74 生成一个临时文件,以"w+b"的模式打开,并返回这个临时流的指针, 75 如果失败返回NULL。在程序结束时,这个文件会被自动删除。 76 FILE *fp=tmpfile(); 77 16.tmpnam(); 78 char *tmpnam(char *s); 79 生成一个唯一的文件名, 80 其实tmpfile()就调用了此函数,参数s用来保存得到的文件名,并返回这个指针, 81 如果失败,返回NULL。 82 tmpnam(str1); 83 84 二、直接I/O文件操作 85 这是C提供的另一种文件操作,它是通过直接存/取文件来完成对文件的处理,而上篇所说流式文件操作是通过缓冲区来进行;流式文件操作是围绕一个FILE指针来进行,而此类文件操作是围绕一个文件的“句柄”来进行,什么是句柄呢?它是一个整数,是系统用来标识一个文件(在WINDOWS中,句柄的概念扩展到所有设备资源的标识)的唯一的记号。此类文件操作常用的函数如下表,这些函数及其所用的一些符号在io.h和fcntl.h中定义,在使用时要加入相应的头文件。 86 87 1.open() 88 打开一个文件并返回它的句柄,如果失败,将返回一个小于0的值 89 int open(const char *path, int access [, unsigned mode]); 90 path是要打开的文件名,access是打开的模式, 91 mode是可选项。表示文件的属性,主要用于UNIX系统中,在DOS/WINDOWS这个参数没有意义 92 93 打开模式如下 94 O_RDONLY 只读方式 O_WRONLY 只写方式 O_RDWR 读/写方式 95 O_NDELAY 用于UNIX系统 O_APPEND 追加方式 O_CREAT 如果文件不存在就创建 96 O_TRUNC 把文件长度截为0 O_EXCL 和O_CREAT连用, 97 如果文件存在返回错误 O_BINARY 二进制方式 98 O_TEXT 文本方式 99 100 int handle=open("c:\\msdos.sys",O_BINARY|O_CREAT|O_WRITE); 101 2.close() 102 close(handle) 103 3.lseek() 104 此函数返回执行后文件新的存取位置。 105 lseek(handle,-1234L,SEEK_CUR);//把存取位置从当前位置向前移动1234个字节。 106 x=lseek(hnd1,0L,SEEK_END);//把存取位置移动到文件尾,x=文件尾的位置即文件长度 107 4.read() 108 char x[200]; 109 read(hnd1,x,200); 110 5.write() 111 char x[]="I Love You"; 112 write(handle,x,strlen(x)); 113 7.eof() 114 while(!eof(handle1)){……}; 115 8.filelength() 116 相当于lseek(handle,0L,SEEK_END); 117 long x=filelength(handle); 118 9.rename() 119 rename("c:\\config.sys","c:\\config.w40"); 120 10.chsize(); 121 改变文件长度 122 int chsize(int handle, long size); 123 参数size表示文件新的长度,成功返回0,否则返回-1, 124 如果指定的长度小于文件长度,则文件被截短; 125 如果指定的长度大于文件长度,则在文件后面补"\0"。 126 chsize(handle,0x12345); 127 128 C++: 129 130 在fstream类中 131 一、打开文件 132 void open(const char* filename,int mode,int access); 133 mode:要打开文件的方式: 134 ios::app: 以追加的方式打开文件 135 ios::ate: 文件打开后定位到文件尾,ios:app就包含有此属性 136 ios::binary: 以二进制方式打开文件,缺省的方式是文本方式。两种方式的区别见前文 137 ios::in: 文件以输入方式打开 138 ios::out: 文件以输出方式打开 139 ios::nocreate: 不建立文件,所以文件不存在时打开失败 140 ios::noreplace:不覆盖文件,所以打开文件时如果文件存在失败 141 ios::trunc: 如果文件存在,把文件长度设为0 142 143 access:打开文件的属性 144 0:普通文件,打开访问 145 1:只读文件 146 2:隐含文件 147 4:系统文件 148 149 fstream file1; 150 file1.open("c:\\config.sys",ios::binary|ios::in,0); 151 fstream有两个子类:ifstream和ofstream 152 ifstream file2("c:\\pdos.def");//以输入方式打开文件 153 ofstream file3("c:\\x.123");//以输出方式打开文件 154 155 二、关闭文件 156 file1.close(); 157 三、读写文件 158 1、文本文件的读写 159 file1<<"I Love You";//向文件写入字符串"I Love You" 160 int I; 161 file1>>I;//从文件输入一个整数值。 162 163 操纵符 功能 输入/输出 164 dec 格式化为十进制数值数据 输入和输出 165 endl 输出一个换行符并刷新此流 输出 166 ends 输出一个空字符 输出 167 hex 格式化为十六进制数值数据 输入和输出 168 oct 格式化为八进制数值数据 输入和输出 169 setpxecision(int p) 设置浮点数的精度位数 输出 170 171 要把123当作十六进制输出: 172 file1<<hex<<123; 173 要把3.1415926以5位精度输出: 174 file1<<setpxecision(5)<<3.1415926。 175 2、二进制文件的读写 176 ①put() 177 向流写入一个字符 178 file1.put(‘‘c‘‘); 179 ②get() 180 file2.get(x); 181 x=file2.get();//这种形式是从流中返回一个字符,如果到达文件尾,返回EOF 182 183 file2.get(str1,127,"A");//ifstream &get(char *buf,int num,char delim="\n"); 184 //从文件中读取字符到字符串str1,当遇到字符‘‘A‘‘或读取了127个字符时终止。 185 ③读写数据块 186 read(unsigned char *buf,int num); 187 write(const unsigned char *buf,int num); 188 189 read()从文件中读取 num 个字符到 buf 指向的缓存中,如果在还未读入 num 个字符时就到了文件尾,可以用成员函数 int gcount();来取得实际读取的字符数;而 write() 从buf 指向的缓存写 num 个字符到文件中,值得注意的是缓存的类型是 unsigned char *,有时可能需要类型转换。 190 191 192 unsigned char str1[]="I Love You"; 193 int n[5]; 194 ifstream in("xxx.xxx"); 195 ofstream out("yyy.yyy"); 196 out.write(str1,strlen(str1));//把字符串str1全部写到yyy.yyy中 197 in.read((unsigned char*)n,sizeof(n));//从xxx.xxx中读取指定个整数,注意类型转换 198 in.close();out.close(); 199 200 四、检测EOF 201 eof();如果到达文件尾返回非0值,否则返回0。 202 五、文件定位 203 和C的文件操作方式不同的是,C++ I/O系统管理两个与一个文件相联系的指针 204 一个是读指针,它说明输入操作在文件中的位置;另一个是写指针,它下次写操作的位置。 205 seekg()是设置读位置,seekp是设置写位置 206 207 istream &seekg(streamoff offset,seek_dir origin); 208 ostream &seekp(streamoff offset,seek_dir origin); 209 210 streamoff定义于 iostream.h 中,定义有偏移量 offset 所能取得的最大值 211 seek_dir 表示移动的基准位置,是一个有以下值的枚举 212 ios::beg: 文件开头 213 ios::cur: 文件当前位置 214 ios::end: 文件结尾 215 216 这两个函数一般用于二进制文件, 217 因为文本文件会因为系统对字符的解释而可能与预想的值不同 218 219 file1.seekg(1234,ios::cur);//把文件的读指针从当前位置向后移1234个字节 220 file2.seekp(1234,ios::beg);//把文件的写指针从文件开头向后移1234个字节
时间: 2024-10-02 01:41:23