fread函数

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了fread函数相关的知识,希望对你有一定的参考价值。

1.假设有一个文档,里面记录了学生的信息,且在有一个相对应的结构体,能不能用fread函数将文档里的信息赋给结构体?
2.还有请说明一下fread和fscanf的区别.
3.有人说fread只能进行二进制文件的操作,对吗?
谢谢大家..

1.可以 存储时是按照结构体大小存的话 你就可以直接按大小取出 例如
struct Date
int Day;
int Month;
int Year;
;
struct Date *d1;
fwrite( d,sizeof(Date), 1, fp);//这样写出
struct Date *d2;
fread( d2, sizeof(Date), 1, fp);//这样写入就好了

#include <stdio.h>
int fread( void *buffer, size_t size, size_t num, FILE *stream );
函数fread()读取[num]个对象(每个对象大小为size(大小)指定的字节数),并把它们替换到由buffer(缓冲区)指定的数组. 数据来自给出的输入流. 函数的返回值是读取的内容数量...

int fscanf( FILE *stream, const char *format, ... );
函数fscanf()以scanf()的执行方式从给出的文件流中读取数据. fscanf()的返回值是事实上已赋值的变量的数,如果未进行任何分配时返回EOF.

3.不对 是根据你 是根据你FILE fp=fopen();定义
FILE *fopen( const char *fname, const char *mode );
fopen()函数打开由fname(文件名)指定的文件, 并返回一个关联该文件的流.如果发生错误, fopen()返回NULL. mode(方式)是用于决定文件的用途(例如 用于输入,输出,等等)
Mode(方式) 意义
"r" 打开一个用于读取的文本文件
"w" 创建一个用于写入的文本文件
"a" 附加到一个文本文件
"rb" 打开一个用于读取的二进制文件
"wb" 创建一个用于写入的二进制文件
"ab" 附加到一个二进制文件
"r+" 打开一个用于读/写的文本文件
"w+" 创建一个用于读/写的文本文件
"a+" 打开一个用于读/写的文本文件
"rb+" 打开一个用于读/写的二进制文件
"wb+" 创建一个用于读/写的二进制文件
"ab+" 打开一个用于读/写的二进制文件
参考技术A 1 可以
2 fread 功 能: 从一个流中执行格式化输入
fread 功 能: 从一个流中读数据
3 不对
参考技术B   fread函数,从一个文件流中读数据,最多读取count个元素,每个元素size字节,如果调用成功返回实际读取到的元素个数,如果不成功或读到文件末尾返回 0。

  函数原型
  size_t fread ( void *buffer, size_t size, size_t count, FILE *stream) ;

  参 数
  buffer
  用于接收数据的内存地址

  size
  要读的每个数据项的字节数,单位是字节

  count
  要读count个数据项,每个数据项size个字节.

  stream
  输入流
  

  返回值
  实际读取的元素个数。如果返回值与count不相同,则可能文件结尾或发生错误。从ferror和feof获取错误信息或检测是否到达文件结尾。

matlab 中关于fread函数的用法

用fread打开一个文件时,需要不需要把被打开文件放在某个特定位置?

fread函数在MATLAB中的功能:fread函数可从文件中读取二进制数据

用法:

A = fread(fid, count)

A = fread(fid, count, precision)

其中fid为指针所指文件中的当前位置,count指读取的数据个数, precision表示以什么格式的数据类型读取数据。

扩展资料:

fread函数在PHP中:

(PHP 4, PHP 5)

fread:读取文件(可安全用于二进制文件)

stringfread( int handle, int length )

fread()从文件指针handle读取最多 length 个字节。 该函数在读取完 length 个字节数,或到达 EOF 的时候,或(对于网络流)当一个包可用时就会停止读取文件,视乎先碰到哪种情况。

在区分二进制文件和文本文件的系统上(如 Windows)打开文件时,fopen() 函数的 mode 参数要加上 'b'。

当从网络流或者管道读取时,例如在读取从远程文件或popen()以及proc_open()的返回时,读取会在一个包可用之后停止。这意味着应该如下例所示将数据收集起来合并成大块。

如果只是想将一个文件的内容读入到一个字符串中,用file_get_contents(),它的性能比上面的代码好得多。

参考资料:百度百科-fread函数

参考技术A “fread”以二进制形式,从文件读出数据。
语法1:[a,count]=fread(fid,size,precision)
语法2:[a,count]=fread(fid,size,precision,skip)
size: 不指定 :到尾返回读。
N : 读出N个数据,构成列向量。
inf : 读出fid指向的打开的文件的全部数据。
[M,N] : 读出N个数据,构成列向量,填入M*N矩阵
precision(精度)
precision(精度)规定了以浮点数、整型数、字符读出时位。matlab 的precision(精度)的表达式与c语言、fortran语言、是一致的。不规定precision(精度),则字符默认为: ucher、则数值默认为:双精度 。
以下precision(精度)将保证读出具有一致的体积。
MATLAB C or Fortran Descriphon(精度)
'char' 'char*l' 8 位,字符型
'uchar' 'unsigned char' 8 位
'schar' 'signed char' 8 位,字符型
'int8' 'integer*1' 8 位,整型数
'intl6' 'integer*2' 16 位,整型数.
'int32' 'integer*4' 32 位,整型数.
'int64' 'integer*8' 64 位,整型数
'uint8' 'integer*l' 8 位
'uintl6' 'integer*2' 16 位
'uint32' 'integer*4' 32 位
'uint64' 'integer*8' 64 位
'float32' 'real*4' 浮点数, 32 位
'float64' 'real*8' 浮点数, 32 位

以下precision(精度)将不保证读出具有一致的体积。
MATLAB C or Fortran Descriphon(精度)
'short' 'short' 16 位,整型数
'int' 'int' 32 位,整型数
'long' 'long' 32 (64) 位,整型数
'uShort' 'Unsigned short' 16 位
'uint' 'Unsigned int' 32 位
'ulong' 'unsigned long' 32 (64) 位
'float' 'float' 浮点数, 32 位
'double' 'double' 浮点数, 64 位
以下precision(精度)规定读出指定的体积n。
'bitN' N位,整型数 1<=N<=64
'ubitN' N位, 1<=N<=64
参考技术B 文件必须在Matlab可以搜索的路径中。
一般为提高速度,直接指定位置,比如指定C盘文件myfile
fid=fread('C:\myfile','r')本回答被提问者采纳
参考技术C 当前目录下也是个选择

以上是关于fread函数的主要内容,如果未能解决你的问题,请参考以下文章

fread函数的用法

fread()函数如何判断是不是到文件末尾?

fread函数的用法

fread函数无法正确读取数据

c语言中fread函数怎么用

c语言fread函数的用法