Matlab学习笔记5——fprintf

姓名:李晨睿  学号:22021211235  电子工程学院

Matlab学习笔记5——fprintf

将数据写入文本文件

语法

fprintf(fileID,formatSpec,A1,…,An)

fprintf(formatSpec,A1,…,An)

nbytes = fprintf(___)

说明

fprintf(fileID,formatSpec,A1,…,An) 按列顺序将 formatSpec 应用于数组 A1,…An 的所有元素,并将数据写入到一个文本文件。fprintf 使用在对 fopen 的调用中指定的编码方案。

fprintf(formatSpec,A1,…,An) 设置数据的格式并在屏幕上显示结果。

nbytes = fprintf(___) 使用前述语法中的任意输入参数返回 fprintf 所写入的字节数。

示例

将多个数值和字面文本输出到屏幕。

A1 = [9.9, 9900];

A2 = [8.8,  7.7 ; ...

      8800, 7700];

formatSpec = 'X is %4.2f meters or %8.3f mm\n';

fprintf(formatSpec,A1,A2)

1

2

3

4

5

X is 9.90 meters or 9900.000 mm

X is 8.80 meters or 8800.000 mm

X is 7.70 meters or 7700.000 mm

formatSpec 输入中的 %4.2f 指定输出中每行的第一个值为浮点数,字段宽度为四位数,包括小数点后的两位数。formatSpec 输入中的 %8.3f 指定输出中每行的第二个值为浮点数,字段宽度为八位数,包括小数点后的三位数。\n 为新起一行的控制字符。

将双精度值输出为整数

显式将包含分式的双精度值转换为整数值。

a = [1.02 3.04 5.06];

fprintf('%d\n',round(a));

1

2

1

3

5

formatSpec 输入中的 %d 将向量 round(a) 中的每个值作为有符号整数输出。\n 为新起一行的控制字符。

将表格数据写入文本文件

将指数函数的短表写入到名为 exp.txt 的文本文件。

x = 0:.1:1;

A = [x; exp(x)];

fileID = fopen('exp.txt','w');

fprintf(fileID,'%6s %12s\n','x','exp(x)');

fprintf(fileID,'%6.2f %12.8f\n',A);

fclose(fileID);

1

2

3

4

5

6

7

第一个对 fprintf 的调用输出标题文本 x 和 exp(x),第二个调用输出变量 A 的值。

如果打算使用 Microsoft® 记事本读取文件,请使用 ‘\r\n’ 而不是 ‘\n’ 移到新行。例如,将对 fprintf 的调用替换为下列项:

fprintf(fileID,'%6s %12s\r\n','x','exp(x)');

fprintf(fileID,'%6.2f %12.8f\r\n',A);

1

2

MATLAB® 导入函数、所有 UNIX® 应用程序以及 Microsoft Word 和写字板都将 ‘\n’ 识别为换行指示符。

通过 type 命令查看文件的内容。

type exp.txt

1

x      exp(x)

1

0.00 1.00000000

0.10 1.10517092

0.20 1.22140276

0.30 1.34985881

0.40 1.49182470

0.50 1.64872127

0.60 1.82211880

0.70 2.01375271

0.80 2.22554093

0.90 2.45960311

1.00 2.71828183

获取写入文件的字节数

将数据写入文件并返回所写入的字节数。

将数据数组 A 写入文件并获取 fprintf 所写入的字节数。

A = magic(4);

fileID = fopen('myfile.txt','w');

nbytes = fprintf(fileID,'%5d %5d %5d %5d\n',A)

1

2

3

4

nbytes = 96

fprintf 函数向文件中写入了 96 个字节。

关闭文件。

fclose(fileID);

1

通过 type 命令查看文件的内容。

type(‘myfile.txt’)

16 5 9 4

2 11 7 14

3 10 6 15

13 8 12 1

在命令行窗口中显示超链接

在屏幕上显示超链接(MathWorks 公司网站)。

url = 'https://www.mathworks.com';

sitename = 'The MathWorks Web Site';

fprintf('<a href = "%s">%s</a>\n',url,sitename)

1

2

3

4

formatSpec 输入中的 %s 指示变量 url 和 sitename 的值应作为文本输出。

输入参数

fileID - 文件标识符

1 (默认) | 2 | 标量

文件标识符,指定为下列值之一:

从 fopen 获取的文件标识符。

1 表示标准输出(屏幕)。

2 表示标准错误。

数据类型: double

formatSpec - 输出字段的格式

格式化操作符

输出字段的格式,使用格式化操作符指定。formatSpec 还可以包括普通文本和特殊字符。

如果 formatSpec 包括表示转义字符的字面文本,如 \n,则 fprintf 将转换转义字符。

formatSpec 可以是用单引号引起来的字符向量,从 R2016b 开始,也可以是字符串标量。

格式化操作符

格式化操作符以百分号 % 开头,以转换字符结尾。转换字符是必需的。您也可以在 % 和转换字符之间指定标识符、标志、字段宽度、精度和子类型操作符。(操作符之间的空格无效,在这里显示空格只是为了便于阅读。)

转换字符

此表显示了要将数值和字符数据格式化为文本的转换字符。

值类型 转换 详细信息

有符号整数 %d 或 %i 以 10 为基数

无符号整数 %u 以 10 为基数

%o 以 8 为基数(八进制)

%x 以 16 为基数(十六进制),小写字母 a–f

%X 与 %x 相同,大写字母 A–F

浮点数 %f 定点记数法(使用精度操作符指定小数点后的位数。)

%e 指数记数法,例如 3.141593e+00(使用精度操作符指定小数点后的位数)。

%E 与 %e 相同,但为大写,例如 3.141593E+00(使用精度操作符指定小数点后的位数)。

%g更紧凑的 %e 或 %f,不带尾随零(使用精度操作符指定有效数字位数。)

%G更紧凑的 %E 或 %f,不带尾随零(使用精度操作符指定有效数字位数。)

字符或字符串%c单个字符

%s字符向量或字符串数组。输出文本的类型与 formatSpec 的类型相同。

可选操作符

可选标识符、标志、字段宽度、精度和子类型操作符进一步定义了输出文本的格式。

标识符

处理函数输入参数的顺序。使用语法 n$,其中 n 代表函数调用中其他输入参数的位置。

示例:(‘%3s s %2ss %1s s %2ss’,‘A’,‘B’,‘C’) 将输入参数 ‘A’、‘B’、‘C’ 输出为:C B A B。

注意:如果输入参数为数组,则不能使用标识符指定该输入参数中的特定数组元素。

标志

‘–’

左对齐。

示例:%-5.2f

示例:%-10s

‘+’

始终为任何数值输出符号字符(+ 或 –)。

示例:%+5.2f

右对齐文本。

示例:%+10s

’ ’

在值之前插入空格。

示例:% 5.2f

‘0’

在值之前补零以填充字段宽度。

例如:%05.2f

‘#’

修改选定的数值转换:

对于 %o、%x 或 %X,将输出 0、0x 或 0X 前缀。

对于 %f、%e 或 %E,即使精度为零也将输出小数点。

对于 %g 或 %G,不删除尾随零或小数点。

示例:

字段宽度

要输出的最低字符数。字段宽度操作符可以是数字,也可以是指向输入参数的星号 (*)。

当您将 * 指定为字段宽度操作符时,其他输入参数必须指定打印宽度和要打印的值。宽度和值可以是参数对组,也可以是数值数组中的对组。使用 * 作为字段宽度操作符时,您可以打印具有不同宽度的不同值。

示例:输入参数 (‘%12d’,intmax) 等效于 (‘%*d’,12,intmax)。

示例:输入参数 (‘%*d’,[2 10 5 100]) 返回 ‘10 100’,其中两个空格分配给 10,五个空格分配给 100。您也可以将字段宽度和值指定为多个参数,如 (‘%*d’,2,10,5,100) 中所示。

除非标志另行指定,否则该函数使用空格填充值之前的字段宽度。

精度

对于 %f、%e 或 %E

小数点右侧的位数

示例:‘%.4f’ 将 pi 输出为 ‘3.1416’

对于 %g 或 %G

有效位数

示例:‘%.4g’ 将 pi 输出为 ‘3.142’

精度操作符可以是数字,也可以是指向参数的星号 (*)。

当您将 * 指定为字段精度操作符时,其他输入参数必须指定打印精度和要打印的值。精度和值可以是参数对组,也可以是数值数组中的对组。使用 * 作为精度操作符时,您可以打印具有不同精度的不同值。

将 . 指定为字段宽度和精度操作符时,必须以三元组形式指定字段宽度、精度和值。

示例:输入参数 (‘%.4f’,pi) 等效于 (‘%.*f’,4,pi)。

示例:输入参数 (‘%6.4f’,pi) 等效于 (‘%.*f’,6,4,pi)。

示例:输入参数 (‘%*.*f’,6,4,pi,9,6,exp(1)) 返回 ‘3.1416 2.718282’,其中以 9 和 6 分别作为 exp(1) 输出的字段宽度和精度。

注意

如果您为浮点值指定的精度操作符所表示的精度超出输入数值数据类型的精度,则在指定精度内,结果与输入值可能不匹配。结果取决于您的计算机硬件和操作系统。

子类型

可以使用子类型操作符将浮点值显示为八进制、十进制或十六进制值。子类型操作符紧邻转换字符之前。此表显示了可使用子类型的转换。

输入值类型

子类型和转换字符

输出值类型

浮点数

%bx 或 %bX

%bo

%bu

双精度十六进制、八进制或十进制值

例如:%bx 将 pi 输出为 400921fb54442d18

%tx 或 %tX

%to

%tu

单精度十六进制、八进制或十进制值

例如:%tx 将 pi 输出为 40490fdb

格式化操作符前或后的文本

formatSpec 还可以在百分号 % 前添加其他文本,或者在转换字符后添加其他文本。文本可以为:

要打印的普通文本。

您无法作为普通文本输入的特殊字符。此表显示了如何在 formatSpec 中表示特殊字符。

特殊字符

表示形式

单引号

‘’

百分比字符

%%

反斜杠

\

警报

\a

退格符

\b

换页符

\f

换行符

\n

回车符

\r

水平制表符

\t

垂直制表符

\v

其 Unicode® 数值可以通过十六进制数 N 表示的字符

\xN

示例:sprintf(‘\x5A’) 返回 ‘Z’

其 Unicode 数值可以通过八进制数 N 表示的字符

\N

示例:sprintf(‘\132’) 返回 ‘Z’

使用格式化操作符进行转换时要注意的行为

数值转换仅输出复数的实部。

如果指定不适合数据的转换(例如数值的文本转换),MATLAB 将改写指定的转换并使用 %e。

示例:‘%s’ 将 pi 转换为 3.141593e+00。

如果对整数值应用文本转换(%c 或 %s),MATLAB 会将对应于有效字符代码的值转换为字符。

示例:‘%s’ 将 [65 66 67] 转换为 ABC。

A1,…,An - 数值数组或字符数组

标量 | 向量 | 矩阵 | 多维数组

数值数组或字符数组,指定为标量、向量、矩阵或多维数组。

数据类型: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | logical | char

输出参数

全部折叠

nbytes - 字节数

标量

fprintf 所写入的字节数,作为标量返回。在写入文件时,nbytes 由字符编码所决定。向屏幕输出数据时,nbytes 是屏幕上显示字符的个数。

提示

读取函数 sscanf 和 fscanf 的格式设定符不同于写入函数 sprintf 和 fprintf 的格式。读取函数不支持精度字段。宽度字段在写入函数中指定最小值,但在读取函数中指定最大值。

如果您指定了无效的格式化操作符或特殊字符,则 fprintf 会输出所有文本,直到出现无效的操作符或字符,并丢弃其余部分。

示例:如果 formatSpec 是 ‘value = %z’,则 fprintf 将输出 ‘value =’,因为 %z 不是格式化操作符。

示例:如果 formatSpec 是 ‘character \x99999 = %s’,则 fprintf 将输出 ‘character’,因为 \x99999 不是有效的特殊字符。

————————————————

版权声明:本文为CSDN博主「i_can_do_nothing」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/i_can_do_nothing/article/details/128256211

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • ^函数重载的匹配: 当函数名被重载后,函数的匹配过程:首先寻找能精确匹配的函数,如果未能精确匹配,则尝试...
    鲁大帅阅读 4,699评论 0 1
  • 格式化 gofmt是一个cli程序,会优先读取标准输入,如果传入了文件路径的话,会格式化这个文件,如果传入一个目录...
    半亩房顶阅读 2,607评论 0 2
  • Chez Scheme遵从R6RS 规范chez scheme 中输入 (apropos 'scheme) (a...
    onedam阅读 5,115评论 0 1
  • 初识C++ C++标准格式 变量 作用:给一段指定的内存空间起名,方便操作这段内存。语法:数据类型 变量名 = ...
    home2_d685阅读 1,693评论 0 0
  • 人生苦短我用 Python 注:最后附电子书地址 一、Pythonic Thinking 第1条: 确认自己所用的...
    molscar阅读 6,335评论 0 3

友情链接更多精彩内容