** fopen 和 fread 的用法 **

一、fopen

打开文件或获得有关打开文件的信息

说明:

(1) fileID = fopen(filename)
打开文件 filename 以便以二进制读取形式进行访问,
并返回等于或大于 3 的整数文件标识符。
MATLAB® 保留文件标识符 0、1 和 2 分别用于标准输入、标准输出(屏幕)和标准错误。如果 fopen 无法打开文件,则 fileID 为 -1。

(2) fileID = fopen(filename,permission)
将打开由 permission 指定访问类型的文件。

(3) fileID = fopen(filename,permission,machinefmt,encodingIn)
使用 machinefmt 参数另外指定在文件中读写字节或位时的顺序。
可选的 encodingIn 参数指定与文件相关联的字符编码方案。

(4) fIDs = fopen(‘all’)
返回包含所有打开文件的文件标识符的行向量。
为标准输入、输出以及错误而保留的标识符不包括在内。
向量中元素的数量等于打开文件的数量。

(5) filename = fopen(fileID)
返回上一次调用 fopen 在打开 fileID 指定的文件时所使用的文件名。
输出文件名将解析到完整路径。
fopen 函数不会从文件读取信息来确定输出值。

(6) [filename,permission,machinefmt,encodingOut] = fopen(fileID)
返回上一次调用 fopen 在打开指定文件时所使用的权限、计算机格式以及编码。
如果是以二进制模式打开的文件,则 permission 会包含字母 ‘b’。
encodingOut 输出是一个标准编码方案名称。
fopen 不会从文件读取信息来确定这些输出值。
无效的 fileID 会为所有输出参数返回空字符向量。

输入参数:
(1)filename - 要打开的文件的名称,字符向量或字符串标
要打开的文件名称(含文件扩展名),指定为字符行向量或字符串标量。如果该文件不在当前文件夹中,则 filename 必须包含完整或相对路径。
(2)permission - 文件访问类型
‘r’ (默认) | ‘w’ | ‘a’ | ‘r+’ | ‘w+’ | ‘a+’ | ‘A’ | ‘W’ | …
在这里插入图片描述另外,在这些字符串后添加一个“t”,如‘rt’或‘wt+’,则将该文件以文本方式打开;如果添加的是“b”,则以二进制格式打开,这也是fopen函数默认的打开方式。
(3)machinefmt - 读取或写入字节或位的顺序
‘n’ (默认) | ‘b’ | ‘l’ | ‘s’ | ‘a’ | …
在这里插入图片描述
(4)encodingIn - 字符编码
‘UTF-8’ | ‘ISO-8859-1’ | ‘windows-1251’ | ‘windows-1252’ | …
(5)fileID - 已打开文件的文件标识符-整数
已打开文件的文件标识符,指定为整数。

二、fread

读取二进制文件中的数据

说明:
(1)A = fread(fileID)
将打开的二进制文件中的数据读取到列向量 A 中,
并将文件指针定位在文件结尾标记处。
该二进制文件由文件标识符 fileID 指示。
使用 fopen 可打开文件并获取 fileID 值。
读取文件后,请调用 fclose(fileID) 来关闭文件。

(2)A = fread(fileID,sizeA)
将文件数据读取到维度为 sizeA 的数组 A 中,
并将文件指针定位到最后读取的值之后。
fread 按列顺序填充 A。

(3)A = fread(fileID,sizeA,precision)
根据 precision 描述的格式和大小解释文件中的值。
sizeA 参数为可选参数。

(4)A = fread(fileID,sizeA,precision,skip)
在读取文件中的每个值之后将跳过 skip 指定的字节或位数。
sizeA 参数为可选参数。

(5)A = fread(fileID,sizeA,precision,skip,machinefmt)
另外指定在文件中读取字节或位时的顺序。
sizeA 和 skip 参数是可选的。

输入参数:

(1)fileID - 文件标识符(整数)
已打开二进制文件的文件标识符,指定为整数。
使用 fread 读取文件之前,使用 fopen 打开文件并获取 fileID。
(2)sizeA - 输出数组的维度(Inf (默认) | 整数 | 二元素行向量)
在这里插入图片描述
(3)precision - 要读取的值的类和大小
(‘uint8=>double’ (默认) | 字符向量或字符串标量)
参考文章

(4)skip - 要跳过的字节数

(5)machinefmt - 读取字节的顺序
‘n’ (默认) | ‘b’ | ‘l’ | ‘s’ | ‘a’ | …

输出参数:

(1)A - 文件数据 列向量 | 矩阵
文件数据,以列向量形式返回。如果指定 sizeA 参数,则 A 是指定大小的矩阵。A 中的数据为类 double,除非在 precision 参数中指定不同的类。

(2)count - 读取的字符数(标量)
读取的字符数,以标量值形式返回

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值