QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 5141|回复: 0
打印 上一主题 下一主题

borland c++ bulder的文件操作总结-1

[复制链接]
字体大小: 正常 放大
韩冰        

823

主题

3

听众

4048

积分

我的地盘我做主

该用户从未签到

发帖功臣 元老勋章

跳转到指定楼层
1#
发表于 2005-1-26 13:07 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
<>、基于C的文件操作
/ r( p- b- w$ b$ q4 D1 I% R  在ANSI C中,对文件的操作分为两种方式,即流式文件操作和I/O文件操作,下面就分别介绍之。</P>' h7 q8 S- [% g$ R2 y  V! G7 Z
<>一、流式文件操作. K" s7 a7 p- ^4 A1 @' \; k; D1 i; q0 R8 J
  这种方式的文件操作有一个重要的结构FILE,FILE在stdio.h中定义如下:</P>
, A: S! e; {3 M9 ^" b- {- [4 o/ H% [<>typedef struct {
; _2 A0 [; b, J% xint level; /* fill/empty level of buffer */
. q+ G4 I/ z- R! J0 ~& {* ]unsigned flags; /* File status flags */& w# _' Z4 H0 Y
char fd; /* File descriptor */& C; t7 c+ y; ?1 ]- j- y
unsigned char hold; /* Ungetc char if no buffer */! v: U6 u0 e- O  ?) |$ B! _
int bsize; /* Buffer size */" _- ~  J, D1 Q. B  B0 h4 `) Q
unsigned char _FAR *buffer; /* Data transfer buffer */" ^: r" |) r  v+ g: u8 }
unsigned char _FAR *curp; /* Current active pointer */1 G5 q: B1 }) L$ @" {0 R
unsigned istemp; /* Temporary file indicator */
5 {' A6 Z$ S; g. q4 Tshort token; /* Used for validity checking */. e* S; w) H) h1 ]+ r
} FILE; /* This is the FILE object */</P>+ r: t: B* q2 F( [1 P9 E
<>  FILE这个结构包含了文件操作的基本属性,对文件的操作都要通过这个结构的指针来进行,此种文件操作常用的函数见下表 函数 功能
5 M3 v/ Z; g$ ?7 q+ i$ p: jfopen() 打开流
& X; E+ o  R& Z5 ~" Qfclose() 关闭流
9 q: M5 b/ J, b0 c' dfputc() 写一个字符到流中   b3 I6 b+ z! s
fgetc() 从流中读一个字符 : J" N; {: J9 g8 h6 ^
fseek() 在流中定位到指定的字符
6 T# _2 q+ N. I. m7 l# Z0 Z# }. Lfputs() 写字符串到流
2 {7 |+ j, @" j. ~" {fgets() 从流中读一行或指定个字符
6 U% }" y; Z6 U+ ]  O  S- Ffprintf() 按格式输出到流 5 F2 ~# x7 A/ D' S! `% C7 @
fscanf() 从流中按格式读取
! r' y' N, f, @! Y2 ofeof() 到达文件尾时返回真值
1 d8 m5 ~9 E0 R% S% P5 Oferror() 发生错误时返回其值 ) x+ D5 d1 R5 P8 X+ j
rewind() 复位文件定位器到文件开始处 - p) V4 g' x' J" p7 p9 B* x
remove() 删除文件
; W( m0 h- R& c& \/ C$ u/ }/ kfread() 从流中读指定个数的字符
5 q2 M, ^, C, Y5 @" Yfwrite() 向流中写指定个数的字符
# H4 Z0 ?8 L) W: t: ftmpfile() 生成一个临时文件流
7 Q& h* i% p) s. ktmpnam() 生成一个唯一的文件名 </P>7 K9 E1 M) m4 d  |' D) t
<>! t6 {  @7 r- N" S6 _6 V
  下面就介绍一下这些函数</P>9 |1 E% x  r: Z) O2 s
<>1.fopen()
" {# x, l: @% K4 E/ [& i  fopen的原型是:FILE *fopen(const char *filename,const char *mode),fopen实现三个功能</P>. G; i! k' t$ x2 A
<>为使用而打开一个流 / ]# ?7 u) p( Q% w( h
把一个文件和此流相连接
& Y& n6 \4 u: q6 o+ Z给此流返回一个FILR指针
) Q! n- z* @* j& P- W8 o! C& F7 z参数filename指向要打开的文件名,mode表示打开状态的字符串,其取值如下表</P>
4 l  ?, V0 @4 D" z/ K1 k<>字符串 含义 * \# z* w- W3 z2 @- y
"r" 以只读方式打开文件
$ D- b+ g3 e# u3 S# T"w" 以只写方式打开文件 1 ^) y$ L; F7 a9 A4 @" \
"a" 以追加方式打开文件 + w. t/ m: t1 G$ c
"r+" 以读/写方式打开文件,如无文件出错   U. C5 |- i) s
"w+" 以读/写方式打开文件,如无文件生成新文件 </P>' m0 _! r3 ?6 ]% Q0 M
<>  一个文件可以以文本模式或二进制模式打开,这两种的区别是:在文本模式中回车被当成一个字符'\n',而二进制模式认为它是两个字符0x0D,0x0A;如果在文件中读到0x1B,文本模式会认为这是文件结束符,也就是二进制模型不会对文件进行处理,而文本方式会按一定的方式对数据作相应的转换。</P>; T3 w' ^% e0 J0 Z  U2 ?
<>  系统默认的是以文本模式打开,可以修改全部变量_fmode的值来修改这个设置,例如_fmode=O_TEXT;就设置默认打开方式为文本模式;而_fmode=O_BINARY;则设置默认打开方式是二进制模式。</P>' P4 U9 L. e+ A) w' y
<>  我们也可以在模式字符串中指定打开的模式,如"rb"表示以二进制模式打开只读文件,"w+t"或"wt+"表示以文本模式打开读/写文件。</P>
& }( r0 f9 Z& X<>  此函数返回一个FILE指针,所以申明一个FILE指针后不用初始化,而是用fopen()来返回一个指针并与一个特定的文件相连,如果成败,返回NULL。</P>
4 r4 u8 E5 |: ], e4 ~, ~<>例:</P>! b+ B2 H/ f+ n: g
<>  FILE *fp;
; |) _" g, t8 z% Z* D4 j  if(fp=fopen("123.456","wb"))
1 }, o- U" n1 L    puts("打开文件成功");. r' `, N; B2 ]+ ?) j
  else
; P$ R, M) W+ f7 H3 @( K# N. {    puts("打开文件成败"); </P># x5 R  E" q0 `) W& x- a
<>2.fclose()
% \' M1 Y+ K5 j& u$ s  fclose()的功能就是关闭用fopen()打开的文件,其原型是:int fclose(FILE *fp);如果成功,返回0,失败返回EOF。</P>
% u, G" K' ~- e: T7 `, \5 V<>  在程序结束时一定要记得关闭打开的文件,不然可能会造成数据丢失的情况,我以前就经常犯这样的毛病。</P>
0 C2 Z2 F6 x& E; I0 y<>例:fclose(fp);</P>
& i* ?2 `% a4 @<>3.fputc()) G5 l: x9 S) @
  向流写一个字符,原型是int fputc(int c, FILE *stream); 成功返回这个字符,失败返回EOF。</P>
4 o: k/ J) c+ d3 |  S<>例:fputc('X',fp);</P>! ?. b! v* P" Z+ a* ~9 @
<>4.fgetc()
- A3 C6 O4 g! O4 ^) ]* Z( U  从流中读一个字符,原型是int fputc(FILE *stream); 成功返回这个字符,失败返回EOF。</P>0 X0 U: c, I4 N! g3 d1 R
<>例:char ch1=fgetc(fp);</P>4 O; W; K/ f0 N, F# _
<>5. fseek()9 U* A# ?4 |8 @2 T5 h# S! y2 h
  此函数一般用于二进制模式打开的文件中,功能是定位到流中指定的位置,原型是int fseek(FILE *stream, long offset, int whence);如果成功返回0,参数offset是移动的字符数,whence是移动的基准,取值是</P>
& m& O- W8 q% C2 x* k+ @6 M( Y<>符号常量 值 基准位置
; r: T3 _2 r5 Q, B  ?SEEK_SET 0 文件开头
4 e; [( ~0 N2 X' e" x7 C2 f; eSEEK_CUR 1 当前读写的位置
3 w; o1 Y+ o# A! O5 y9 nSEEK_END 2 文件尾部 </P>4 x3 w$ N  {8 j' h* _
<>例:fseek(fp,1234L,SEEK_CUR);//把读写位置从当前位置向后移动1234字节(L后缀表示长整数)</P>
- S' |& u9 O. I6 t<>  fseek(fp,0L,2);//把读写位置移动到文件尾</P>
; e# R+ v, s4 M! x3 V1 U<>6.fputs()
8 h& {+ f8 E, [4 a9 m  写一个字符串到流中,原型int fputs(const char *s, FILE *stream); </P>$ w. O* o" \- @9 l' W, p5 `
<>例:fputs("I Love You",fp);</P>
  v" W7 Q  z( X2 y# H7 u<>7.fgets()' m3 |) i: e& e* b4 U- [( f/ X
  从流中读一行或指定个字符,原型是char *fgets(char *s, int n, FILE *stream); 从流中读取n-1个字符,除非读完一行,参数s是来接收字符串,如果成功则返回s的指针,否则返回NULL。</P>2 v% `" e6 Y" d; e
<>例:如果一个文件的当前位置的文本如下</P>
' @4 c4 J0 A) n3 A1 }# u" P# U<>Love ,I Have</P># t9 s) z6 b. a4 S! `2 a- m
<P>But ........</P>
5 J1 `2 h8 r/ Z<P>如果用</P>( N% K) ^, P% C* U4 N5 s! h
<P>  fgets(str1,4,file1);</P>8 J1 }8 J9 U' n5 V2 e1 v1 I/ \
<P>则执行后str1="Lov",读取了4-1=3个字符,而如果用</P>
4 ~& \  }6 I: r% n$ \8 t<P>  fgets(str1,23,file1);</P>5 d$ ?0 v( c# Y6 P, o5 y) @
<P>则执行str="Love ,I Have",读取了一行(不包括行尾的'\n')。</P>, G8 `: S, e" u: |$ I# W
<P>8.fprintf()4 U( d! @1 M8 @
  按格式输入到流,其原型是int fprintf(FILE *stream, const char *format[, argument, ...]);其用法和printf()相同,不过不是写到控制台,而是写到流罢了</P>2 d9 O+ ~! {* |5 r7 i
<P>例:fprintf(fp,"%2d%s",4,"Hahaha");</P>* B$ P3 E+ L4 e
<P>9.fscanf()5 Y2 V) B% t# E: [) I
  从流中按格式读取,其原型是int fscanf(FILE *stream, const char *format[, address, ...]);其用法和scanf()相同,不过不是从控制台读取,而是从流读取罢了。</P>! W* `0 v! I' [( T; |4 j, i
<P>例:fscanf(fp,"%d%d" ,&amp;x,&amp;y);</P>
  e- x/ W' b# d8 Q$ p<P>10.feof()
# p% R& W& i; B% D( {  检测是否已到文件尾,是返回真,否则返回0,其原型是int feof(FILE *stream);</P>" p" f% E: @/ C6 k& b! t) P5 D2 p
<P>例:if(feof(fp))printf("已到文件尾");</P>1 z8 k/ F; P" j  _0 a
<P>11.ferror()7 K5 _. J9 W% b" D9 F8 @
  原型是int ferror(FILE *stream);返回流最近的错误代码,可用clearerr()来清除它,clearerr()的原型是void clearerr(FILE *stream);</P>
5 o, C* ^2 O# p<P>例:printf("%d",ferror(fp));</P>4 M# c; O* }1 }4 B% A9 p
<P>12.rewind()4 g: y8 @; h" ~! Q; }# ^
  把当前的读写位置回到文件开始,原型是void rewind(FILE *stream);其实本函数相当于fseek(fp,0L,SEEK_SET);</P>4 N1 c: V  P4 U9 }0 |4 K# h* H
<P>例:rewind(fp);</P>
* }* A1 y2 t, h6 I- R* j7 a5 t: t<P>12.remove()
5 W- V7 ~% H4 m* E$ Y- \3 B0 f  删除文件,原型是int remove(const char *filename); 参数就是要删除的文件名,成功返回0。</P>; u4 d: |- _8 ?( F- t" w; m8 g
<P>例:remove("c:\\io.sys");</P># [, D! F$ S* K3 f8 h* Y
<P>13.fread(); E9 I7 R: n, W6 h& Q0 I1 E
  从流中读指定个数的字符,原型是size_t fread(void *ptr, size_t size, size_t n, FILE *stream);参数ptr是保存读取的数据,void*的指针可用任何类型的指针来替换,如char*、int *等等来替换;size是每块的字节数;n是读取的块数,如果成功,返回实际读取的块数(不是字节数),本函数一般用于二进制模式打开的文件中。</P>
; T: W* t( j1 X1 t4 B" S9 z% @<P>例:</P>- m) i5 c# E% x6 ]
<P>  char x[4230];
: m( e$ ?* _5 A  r  FILE *file1=fopen("c:\\msdos.sys","r");7 _2 r4 F5 O9 y! Z
  fread(x,200,12 ,file1);//共读取200*12=2400个字节</P>
$ v8 p) u# a; `<P>14.fwrite()  h& D  A6 @: ^( q! M
  与fread对应,向流中写指定的数据,原型是size_t fwrite(const void *ptr, size_t size, size_t n, FILE *stream);参数ptr是要写入的数据指针,void*的指针可用任何类型的指针来替换,如char*、int *等等来替换;size是每块的字节数;n是要写的块数,如果成功,返回实际写入的块数(不是字节数),本函数一般用于二进制模式打开的文件中。</P>
2 J( ^4 R; S) g5 G( y! w<P>例:</P>$ z4 M  s& {4 n' @% {/ j  {
<P>  char x[]="I Love You";( F% ~8 q8 z: X" e7 |
  fwire(x, 6,12,fp);//写入6*12=72字节</P>
7 D/ F, x* E$ v& ]/ ]0 q& W& J<P>  将把"I Love"写到流fp中12次,共72字节</P>
3 e! \5 Z1 }' i  B<P>15.tmpfile()
4 a7 F+ R- Y* _* i+ E8 N# X5 A7 Y  其原型是FILE *tmpfile(void); 生成一个临时文件,以"w+b"的模式打开,并返回这个临时流的指针,如果失败返回NULL。在程序结束时,这个文件会被自动删除。</P>. u- }* B/ E0 K  ]/ i- W$ g
<P>例:FILE *fp=tmpfile();</P>
# g' B; N1 N0 b  _& u/ G  \6 v3 B4 S<P>16.tmpnam();
5 m4 i9 v: u( q0 d; h9 E  其原型为char *tmpnam(char *s); 生成一个唯一的文件名,其实tmpfile()就调用了此函数,参数s用来保存得到的文件名,并返回这个指针,如果失败,返回NULL。</P>
" i  Z) i& Z. t& L
/ H: j3 G" b* N$ D$ I! _1 Y) p<P>; O  l0 _; h" l6 [) h  l
</P>
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-4-20 07:06 , Processed in 0.540851 second(s), 52 queries .

回顶部