• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

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

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

参考:https://ww2.mathworks.cn/help/matlab/ref/fopen.html?searchHighlight=fopen&s_tid=doc_srchtitle

 

个人认为返回的标识符是一个文件句柄handle, 网上的解释是: MATLAB® 保留文件标识符 012 分别用于标准输入、标准输出(屏幕)和标准错误。

 

fopen

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

全页折叠

说明

示例

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

如果 fopen 无法打开文件,则 fileID-1

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

示例

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

示例

如果 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 = fopen(\'tsunamis.txt\');

fileID 传递给 fgetl 函数以从文件读取一行。

tline = fgetl(fileID)
tline =

  \'A global tsunami data set in xlsx format, comprising the following file:\'

关闭文件。

fclose(fileID)

请求要打开的文件的名称

创建一条提示,要求提供待打开文件的名称。如果 fopen 无法打开文件,则显示相关错误消息。

fileID = -1;
errmsg = \'\';
while fileID < 0 
   disp(errmsg);
   filename = input(\'Open file: \', \'s\');
   [fileID,errmsg] = fopen(filename);
end

打开要写入的文件并指定访问类型、写入顺序、字符编码

打开一个文件,使用 Shift-JIS 字符编码写入到文件。

fileID = fopen(\'japanese_out.txt\',\'w\',\'n\',\'Shift_JIS\');

\'w\' 输入指定写入权限,\'n\' 输入指定本机字节排序方式,\'Shift_JIS\' 指定字符编码方案。

获取有关已打开文件的信息

假定您以前使用 fopen 打开了文件。

fileID = fopen(\'tsunamis.txt\');

获取所有已打开文件的文件标识符。

fIDs = fopen(\'all\')
fIDs =

     3

获取已打开文件的文件名称及字符编码。使用 ~ 代替您希望省略的输出参数。

[filename,~,~,encoding] = fopen(fileID)
filename =

    \'matlabroot\toolbox\matlab\demos\tsunamis.txt\'


encoding =

    \'windows-1252\'

这里显示的输出内容有代表性。您的结果可能有所不同。

输入参数

全部折叠

filename - 要打开的文件的名称
字符向量或字符串标量

要打开的文件名称(含文件扩展名),指定为字符行向量或字符串标量。如果该文件不在当前文件夹中,则 filename 必须包含完整或相对路径。

在 UNIX® 系统上,如果 filename\'~/\'\'~username/\' 开头,则 fopen 函数分别延长路径至当前用户或指定用户的主目录。

  • 如要打开有读取权限的文件而该文件不在当前文件夹中,则 fopen 将沿 MATLAB 搜索路径进行搜索。

  • 如要打开有写入或追加权限的文件而该文件不在当前文件夹中,则 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® 系统上,以文本模式:

  • 读取操作如果遇到回车符后加换行符 (\'\r\n\'),则会从输入中删除回车符。

  • 写入操作在输出中的任何换行符之前插入一个回车符。

如果要在 MATLAB 中写入文件,则以文本模式打开或创建新文件,然后在 Microsoft® 记事本或不会将 \'\n\' 识别为换行符序列的任意文本编辑器中打开该文件。写入文件时,用 \'\r\n\' 结束每行。有关示例,请参阅 fprintf。否则,请以二进制模式打开文件以获得更佳的性能。

要读写同一文件:

  • 采用带加号 \'+\'permission 值打开文件。

  • 在读写操作之间调用 fseekfrewind。例如,不在调用 fread 后调用 fwrite,或调用 fwrite 后调用 fread,除非在它们之间调用 fseekfrewind

数据类型: 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\' | ...

后续读写操作使用的字符编码,包括 fscanffprintffgetlfgetsfread 以及 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

提示

  • 在大多数情况下,不必以文本模式打开文件。MATLAB 导入函数、所有 UNIX 应用程序以及 Microsoft Word 和写字板都将 \'\n\' 识别为换行指示符。

扩展功能

C/C++ 代码生成
使用 MATLAB® Coder™ 生成 C 代码和 C++ 代码。

用法说明和限制:

 

  • 代码生成不支持:

    • 输入参数 machinefmtencodingInfileID

    • 输出参数 errmsg

    • 语法 fopen(\'all\')

    • 以文本模式打开文件。即 permission 参数不能包含字母 t。例如,值不能为 \'rt\'

  • permission 参数最多可以包含三个字符。字符必须是唯一的。

  • 如果您禁用外部调用,则不能将使用 fopen 创建的文件标识符返回给 MATLAB 函数或外部函数。这些文件标识符只能在内部使用。

  • 生成 C/C++ 可执行文件、静态库或动态库时,最多可以打开 20 个文件。

  • 生成的代码不会报告因文件标识符无效而产生的错误。请在您自己的 MATLAB 代码中自行编写文件打开错误处理程序。测试 fopen 是否返回 -1,此值表示文件打开失败。例如:

    ...
    fid = fopen(filename, \'r\');
    if fid == -1
    		% fopen failed
    
    else
    % fopen successful, okay to call fread
    A = fread(fid);
    ...

     

  • 当您执行以下操作时,生成的代码对于 fread 的行为取决于编译器:

    1. 使用 fopena+ permission 打开文件。

    2. 在调用设置文件位置指示符的 I/O 函数(如 fseekfrewind)之前,使用 fread 读取文件。

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
在Delphi中判断用户是否有超期未还的书本发布时间:2022-07-18
下一篇:
WindowsAPI的数据类型与Delphi数据类型对照表发布时间:2022-07-18
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap