C stdio fprintf() 函数
定义和用法
fprintf() 函数将一个格式化的字符串写入文件。
fprintf() 函数定义在 <stdio.h> 头文件中。
格式说明符
格式字符串可以包含格式说明符,这些说明符描述了如何以及在何处表示传递给函数的附加参数。
格式说明符的形式为 %[flags][width][.precision][length]specifier。方括号 [ ] 中的组件是可选的。
对每个组件的解释:
flags(标志):可选。以下字符的任意序列:
- |
使输出左对齐,通过在右侧添加填充空格而不是左侧。 |
# |
根据转换显示格式化数据的替代表示。 |
+ |
使正数总是以 "+" 为前缀。 |
| (空格字符) | 为正数添加空格前缀,主要是为了使数字与负数的数字对齐。 |
0 |
在左侧用零填充数字。 |
width(宽度):可选。整数,指定输出应占用的最小字符数。如有必要,会在右侧添加空格以达到此数字,如果使用了 - 标志,则在左侧添加。如果使用 *,则宽度由被表示参数之前的参数给出。
.precision(精度):可选。点号 . 后跟整数,指示在格式化数据中显示多少位小数。
length(长度):可选。字符序列,更改参数的预期数据类型。可以是以下之一:
hh |
期望 char 类型的整数。 |
h |
期望 short int 类型的整数。 |
l |
期望 期望 期望 |
ll |
期望 long long int 类型的整数。 |
j |
期望 intmax_t 或 uintmax_t 类型的整数。 |
z |
期望 size_t 类型的整数。 |
t |
期望 ptrdiff_t 类型的整数。 |
L |
期望 long double 类型的浮点数。 |
specifier(说明符):必需。字符,指示应如何表示参数的数据。可能的字符列表如下表所示。
说明符列表
| 字符 | 说明符 | 描述 |
|---|---|---|
d 或 i |
十进制整数 | 将整数表示为十进制整数。 |
u |
无符号十进制整数 | 将整数表示为无符号十进制整数。 |
o |
八进制整数 | 将整数表示为八进制整数。# 标志会在数字前加上 "0"。 |
x 或 X |
十六进制整数 |
将整数表示为十六进制整数。 如果使用 "X",则数字 |
f 或 F |
浮点数 |
表示浮点数。 如果使用 "
|
e 或 E |
科学计数法 |
以科学计数法表示浮点数。 如果使用 "
|
g 或 G |
通用数字 |
对浮点数使用 如果使用 " |
a 或 A |
十六进制浮点数 |
用十六进制数字写入浮点数的内部表示。 如果使用 " |
c |
字符 |
表示一个字符。 如果参数是整数,则表示由整数指定的 ASCII 值的字符。 |
s |
字符串 | 表示一个字符串。 |
p |
指针 | 表示指针的内存地址,通常用十六进制数字。 |
n |
无输出 |
将到目前为止写入文件的字符数写入参数。 参数必须是指向整数的指针。 |
% |
百分号 | 表示字面量 "%" 字符。 |
在 printf() 函数参考页 中可以找到如何使用格式说明符的各种实例。
实例
写入文件:
FILE *fptr;
// 以写入模式打开文件
fptr = fopen("filename.txt", "w");
// 向文件写入一些文本
fprintf(fptr, "Some text");
// 关闭文件
fclose(fptr);
语法
fprintf(FILE * fptr, const char * format, arg1, arg2...);
参数
| 参数 | 描述 |
|---|---|
| fptr | 必需。文件指针,通常由 fopen() 函数创建。 |
| format | 必需。字符串,表示要写入文件的数据格式。 |
| arg1, arg2... | 可选。任意数量的附加参数,它们的值可以通过格式参数中的说明符进行格式化并写入文件。 |
技术细节
| 返回: |
如果发生错误,则返回负数。 |
|---|