鱼C论坛

 找回密码
 立即注册
查看: 8076|回复: 4

[函数快查] fprintf -- 格式化输出到文件

[复制链接]
发表于 2017-7-16 23:50:23 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
fprintf 函数文档


函数概要:

fprintf 函数用于打印格式化字符串到指定的文件。


函数原型:

  1. #include <stdio.h>
  2. ...
  3. int fprintf(FILE *stream, const char *format, ...);
复制代码


参数解析:

1、stream 参数

该参数是一个 FILE 对象的指针,指定一个待操作的数据流。


2、format 参数

format 参数是一个格式化字符串,由格式化占位符和普通字符组成。

格式化占位符(以 % 开头)用于指明输出的参数值如何格式化。


格式化占位符的语法如下:

%[flags][width][.precision][length]specifier

每一个格式化占位符均以 % 开始,以转换字符结束。


specifier转换字符,必选)的内容及含义如下:

转换字符
参数类型;转换结果
c
char;字符
d
int;有符号十进制整数
i
同上
e
double;以指数形式输出单、双精度浮点数(小写 e)
E
同上(大写 E)
f
double;以小数形式输出单、双精度浮点数
g
double;以 %f 或 %e 中较短的输出宽度输出单、双精度浮点数(指数显示小写 e)
G
同上(指数显示大写 E)
o
unsigned int;无符号八进制(无前导 0)
s
char *;字符串
u
int;无符号十进制
x
unsigned int;无符号十六进制(无前导 0x)
X
同上(无前导 0X)
p
void *;指针值
n
int *;存放已写字符的个数
%
不进行参数转换;% 自身

注:如果 % 后边的字符不是转换字符,则其行为没有定义。


flags标志,可选)的内容即含义如下:

标志
含义
-
指定被转换的参数在其字段内左对齐(默认是右对齐)
+
指定在输出的数前面加上正负号
空格
如果第一个字符不是正负号,则在其前面加上一个空格
0
对于数值转换,当输出长度小于字段宽度时,添加前导 0 进行填充
#
指定另一种输出形式:
1. 如果转换字符为 o,则第一个数字为 0
2. 如果转换字符为 x 或 X,则指定在输出的非 0 值钱加 0x 或 0X
3. 对于转换字符为 e、E、f、g 或 G 的情况,指定输出总是包含一个小数点。另外,对于转换字符为 g 或 G,还指定输出值尾部无意义的 0 将被保留

注:flags 可同时出现多个,且无顺序要求。


width(宽度,可选)是一个数值,用于指定最小字段的宽度

转换后的参数输出宽度至少要达到这个数值。如果参数的字符数小于该数值,则在参数左边(如果 flags 设置为 -,要求左对齐的话则在右边)填充一些字符。填充字符通常为空格,但是如果 flags 设置为 0,则填充字符为数字 0。


.precision(.精度,可选),通过点号(.)分隔字段的宽度和精度

  • 对于字符串,它指定打印的字符的最大个数
  • 对于整数,它指定打印的数字位数(必要时可加填充位 0 以达到宽度要求)
  • 对于转换字符为 e、E 或 f,它指定打印的小数点后的数字位数
  • 对于转换字符为 g 或 G,它指定打印的有效数字位数


length(长度修饰符,可选)的值可以是 h、hh、l、ll 或 L

  • hh 表示将相应的参数按 signed char 或 unsigned char 类型输出
  • h 表示将相应的参数按 short 或 unsigned short 类型输出
  • l 表示将相应的参数按 long 或 unsigned long 类型输出
  • ll 表示将相应的参数按 long long 或 unsigned long long 类型输出
  • L 表示将相应的参数按 long double 类型输出


3、... 附加参数

该参数的个数由格式化字符串决定。

每个参数的值应当与前面格式化字符串中的占位符类型和位置一一对应。


返回值:

如果函数调用成功,返回值是实际打印的字符数(不包含表示字符串结束的 '\0');

如果函数调用失败,返回值是一个负数。


演示:

  1. #include <stdio.h>
  2. #include <stdlib.h>

  3. int main(void)
  4. {
  5.         FILE *fp;

  6.         if ((fp = fopen("file.txt", "w")) == NULL)
  7.         {
  8.                 printf("打开文件失败!\n");
  9.                 exit(EXIT_FAILURE);
  10.         }

  11.         fprintf(fp, "I love FishC.com!\n");
  12.         fprintf(fp, "Today is %d-%d-%d\n", 2017, 7, 16);

  13.         fclose(fp);

  14.         return 0;
  15. }
复制代码

搜狗截图20170716235528.png


想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2018-3-4 21:13:02 From FishC Mobile | 显示全部楼层
1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2019-1-21 16:49:44 | 显示全部楼层
2
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2020-4-2 18:01:41 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
发表于 2020-9-13 21:25:30 | 显示全部楼层
4
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1

GMT+8, 2021-1-16 10:35

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表