転載元: http://blog.csdn.net/wl_soft50/article/details/7787521
コードを読んでいると、昔使っていた fseek() が出てきましたが、長い間使っていなかったので、ちょっと不思議な感じがしたので、次回参考までに書いてみます。
この関数の機能は、ファイル ポインターがファイルの先頭を指すことです。ヘッダー ファイル stdio.h をインクルードする必要があります。
fseek
- #include <stdio.h>
- 長い ファイルサイズ( FILE *ストリーム);
- int main( void )
- {
- ファイル *ストリーム;
- stream = fopen( "MYFILE.TXT" , "w+" );
- fprintf(stream, "これはテストです" );
- printf( "MYFILE.TXT のファイルサイズは %ld バイトです\n" , filesize(stream));
- fclose(ストリーム);
- 0 を返します。
- }
- 長い ファイルサイズ( FILE *ストリーム)
- {
- 長い カーポス、長さ。
- curpos = ftell(ストリーム);
- fseek(ストリーム、0L、SEEK_END);
- 長さ = ftell(ストリーム);
- fseek(ストリーム、カーポス、SEEK_SET);
- 戻り 長さ;
- }
- #include <stdio.h>
- #define N 5
- typedef struct student {
- long sno;
- char name[10];
- float score[3];
- } STU;
- void fun(char *filename, STU n)
- {
- FILE *fp;
- fp = fopen(filename, "rb+");
- fseek(fp, -1L*sizeof(STU),SEEK_END);
- fwrite(&n, sizeof(STU), 1, fp);
- fclose(fp);
- }
- void main()
- {
- STU t[N]={ {10001,"MaChao", 91, 92, 77}, {10002,"CaoKai", 75, 60, 88},
- {10003,"LiSi", 85, 70, 78}, {10004,"FangFang", 90, 82, 87},
- {10005,"ZhangSan", 95, 80, 88}};
- STU n={10006,"ZhaoSi", 55, 70, 68}, ss[N];
- int i,j; FILE *fp;
- fp = fopen("student.dat", "wb");
- fwrite(t, sizeof(STU), N, fp);
- fclose(fp);
- fp = fopen("student.dat", "rb");
- fread(ss, sizeof(STU), N, fp);
- fclose(fp);
- printf("\nThe original data :\n\n");
- for (j=0; j<N; j++)
- {
- printf("\nNo: %ld Name: %-8s Scores: ",ss[j].sno, ss[j].name);
- for (i=0; i<3; i++)
- printf("%6.2f ", ss[j].score[i]);
- printf("\n");
- }
- fun( "student.dat" , n);
- printf( "\n変更後のデータ:\n\n" );
- fp = fopen( "student.dat" , "rb" );
- fread(ss, sizeof (STU), N, fp);
- fclose(fp);
- for (j=0; j<N; j++)
- {
- printf( "\nいいえ: %ld 名前: %-8s スコア: " ,ss[j].sno, ss[j].name);
- for (i=0; i<3; i++)
- printf( "%6.2f " , ss[j].score[i]);
- printf( "\n" );
- }