参考:https://ww2.mathworks.cn/help/matlab/ref/fopen.html?searchHighlight=fopen&s_tid=doc_srchtitle
个人认为返回的标识符是一个文件句柄handle, 网上的解释是: MATLAB® 保留文件标识符 0、1 和 2 分别用于标准输入、标准输出(屏幕)和标准错误。
fopen
说明
示例
fileID = fopen(filename) 打开文件 filename 以便以二进制读取形式进行访问,并返回等于或大于 3 的整数文件标识符。MATLAB® 保留文件标识符 0、1 和 2 分别用于标准输入、标准输出(屏幕)和标准错误。
如果 fopen 无法打开文件,则 fileID 为 -1。
示例
如果 fopen 打开文件失败,则 [fileID,errmsg] = fopen(___) 还将返回一条因系统而异的错误消息。否则,errmsg 是一个空字符向量。您可以将此语法与前面语法中的任何输入参数结合使用。
示例
fIDs = fopen('all') 返回包含所有打开文件的文件标识符的行向量。为标准输入、输出以及错误而保留的标识符不包括在内。向量中元素的数量等于打开文件的数量。
filename = fopen(fileID) 返回上一次调用 fopen 在打开 fileID 指定的文件时所使用的文件名。输出文件名将解析到完整路径。fopen 函数不会从文件读取信息来确定输出值。
示例
[filename,permission,machinefmt,encodingOut] = fopen(fileID) 还会返回上一次调用 fopen 在打开指定文件时所使用的权限、计算机格式以及编码。如果是以二进制模式打开的文件,则 permission 会包含字母 'b'。encodingOut 输出是一个标准编码方案名称。fopen 不会从文件读取信息来确定这些输出值。无效的 fileID 会为所有输出参数返回空字符向量。
示例
全部折叠
打开文件并将标识符传递给文件 I/O 函数
打开文件并将文件标识符传递给 fgetl 函数以读取数据。
打开文件 tsunamis.txt 并获取文件标识符。
将 fileID 传递给 fgetl 函数以从文件读取一行。
tline =
'A global tsunami data set in xlsx format, comprising the following file:'
关闭文件。
请求要打开的文件的名称
创建一条提示,要求提供待打开文件的名称。如果 fopen 无法打开文件,则显示相关错误消息。
打开要写入的文件并指定访问类型、写入顺序、字符编码
打开一个文件,使用 Shift-JIS 字符编码写入到文件。
'w' 输入指定写入权限,'n' 输入指定本机字节排序方式,'Shift_JIS' 指定字符编码方案。
获取有关已打开文件的信息
假定您以前使用 fopen 打开了文件。
获取所有已打开文件的文件标识符。
获取已打开文件的文件名称及字符编码。使用 ~ 代替您希望省略的输出参数。
filename =
'matlabroot\toolbox\matlab\demos\tsunamis.txt'
encoding =
'windows-1252'
这里显示的输出内容有代表性。您的结果可能有所不同。
输入参数
全部折叠
filename - 要打开的文件的名称
字符向量或字符串标量
要打开的文件名称(含文件扩展名),指定为字符行向量或字符串标量。如果该文件不在当前文件夹中,则 filename 必须包含完整或相对路径。
在 UNIX® 系统上,如果 filename 以 '~/' 或 '~username/' 开头,则 fopen 函数分别延长路径至当前用户或指定用户的主目录。
示例: 'myFile.txt'
数据类型: char | string
permission - 文件访问类型
'r' (默认) | 'w' | 'a' | 'r+' | 'w+' | 'a+' | 'A' | 'W' | ...
文件访问类型,指定为字符向量或字符串标量。您可以用二进制模式或文本模式打开文件。在 UNIX 系统上,两种转换模式具有相同的效果。要以二进制模式打开文件,请指定以下各项之一。
|
'r'
|
打开要读取的文件。
|
|
'w'
|
打开或创建要写入的新文件。放弃现有内容(如果有)。
|
|
'a'
|
打开或创建要写入的新文件。追加数据到文件末尾。
|
|
'r+'
|
打开要读写的文件。
|
|
'w+'
|
打开或创建要读写的新文件。放弃现有内容(如果有)。
|
|
'a+'
|
打开或创建要读写的新文件。追加数据到文件末尾。
|
|
'A'
|
打开文件以追加(但不自动刷新)当前输出缓冲区。
|
|
'W'
|
打开文件以写入(但不自动刷新)当前输出缓冲区。
|
要以文本模式打开文件,请将字母 't' 附加到 permission 参数,例如 'rt' 或 'wt+'。
在 Windows® 系统上,以文本模式:
如果要在 MATLAB 中写入文件,则以文本模式打开或创建新文件,然后在 Microsoft® 记事本或不会将 '\n' 识别为换行符序列的任意文本编辑器中打开该文件。写入文件时,用 '\r\n' 结束每行。有关示例,请参阅 fprintf。否则,请以二进制模式打开文件以获得更佳的性能。
要读写同一文件:
数据类型: char | string
machinefmt - 读取或写入字节或位的顺序
'n' (默认) | 'b' | 'l' | 's' | 'a' | ...
在文件中读取或写入字节或位的顺序,指定为以下字符向量或字符串标量之一。
|
'n' 或 'native'
|
系统字节排序方式(默认)
|
|
'b' 或 'ieee-be'
|
Big-endian 排序
|
|
'l' 或 'ieee-le'
|
Little-endian 排序
|
|
's' 或 'ieee-be.l64'
|
Big-endian 排序,64 位长数据类型
|
|
'a' 或 'ieee-le.l64'
|
Little-endian 排序,64 位长数据类型
|
默认情况下,当前支持的所有平台都使用 little-endian 排序方式对新文件进行排序。现有二进制文件可以使用 big-endian 或 little-endian 排序方式。
数据类型: char | string
encodingIn - 字符编码
'UTF-8' | 'ISO-8859-1' | 'windows-1251' | 'windows-1252' | ...
后续读写操作使用的字符编码,包括 fscanf、fprintf、fgetl、fgets、fread 以及 fwrite,指定为字符向量或字符串标量。该字符向量或字符串标量必须包含标准字符编码方案名称,如下所示。
|
'Big5'
|
'ISO-8859-1'
|
'windows-874'
|
|
'Big5-HKSCS'
|
'ISO-8859-2'
|
'windows-949'
|
|
'CP949'
|
'ISO-8859-3'
|
'windows-1250'
|
|
'EUC-KR'
|
'ISO-8859-4'
|
'windows-1251'
|
|
'EUC-JP'
|
'ISO-8859-5'
|
'windows-1252'
|
|
'EUC-TW'
|
'ISO-8859-6'
|
'windows-1253'
|
|
'GB18030'
|
'ISO-8859-7'
|
'windows-1254'
|
|
'GB2312'
|
'ISO-8859-8'
|
'windows-1255'
|
|
'GBK'
|
'ISO-8859-9'
|
'windows-1256'
|
|
'IBM866'
|
'ISO-8859-11'
|
'windows-1257'
|
|
'KOI8-R'
|
'ISO-8859-13'
|
'windows-1258'
|
|
'KOI8-U'
|
'ISO-8859-15'
|
'US-ASCII'
|
| |
'Macintosh'
|
'UTF-8'
|
| |
'Shift_JIS'
|
|
如果您不指定编码方案,fopen 将使用系统的默认编码方案打开文件进行处理。有关详细信息,请参阅使用不同的字符编码打开文件。
如果为编码指定的值不在支持的值列表中,则 MATLAB 会发出警告。有时(并非总是)指定其他编码名称会产生正确的结果。
数据类型: char | string
fileID - 已打开文件的文件标识符
整数
已打开文件的文件标识符,指定为整数。
数据类型: double
扩展功能
C/C++ 代码生成
使用 MATLAB® Coder™ 生成 C 代码和 C++ 代码。
用法说明和限制:
-
代码生成不支持:
-
permission 参数最多可以包含三个字符。字符必须是唯一的。
-
如果您禁用外部调用,则不能将使用 fopen 创建的文件标识符返回给 MATLAB 函数或外部函数。这些文件标识符只能在内部使用。
-
生成 C/C++ 可执行文件、静态库或动态库时,最多可以打开 20 个文件。
-
生成的代码不会报告因文件标识符无效而产生的错误。请在您自己的 MATLAB 代码中自行编写文件打开错误处理程序。测试 fopen 是否返回 -1,此值表示文件打开失败。例如:
-
当您执行以下操作时,生成的代码对于 fread 的行为取决于编译器:
-
使用 fopen 和 a+ permission 打开文件。
-
在调用设置文件位置指示符的 I/O 函数(如 fseek 或 frewind)之前,使用 fread 读取文件。