C语言printf的输出格式大全及颜色字体打印

简介: C语言printf的输出格式大全及颜色字体打印



printf函数形式如下

int printf(const char8formation,…);

该函数的功能是将格式化的数据打印到输出端。

转换说明符如下

逐个进行详解(关于与转义字符配合使用详见转义字符

%d%i打印十进制整形数据

标志(flags)

  • 减号:结果左对齐,右边填补空格。默认是右对齐,左边填空格
    d前边的数字控制打印宽度。

  • +加号:输出正负号

  • 空格:输出为正时,正号用空格替代,如果输出为负数,空格被负号替代。

例如:

  • 井号(#):如果打印类型分别为%o,%x,%X时,增加前缀0,0x,0X。

如果type是a,A,e,E,f,g,G时,一定要保留小数点。默认情况下如果使用.0控制保留小数点后0位,这样是不输出小数点的,加上#标志即可显示小数点。

目录中还有%g,是不输出多余的零,加上#就可以保留小数点后的0.

  • 0,数字零

在前边控制打印宽度时,将默认补空格改为补0

例如

%u打印无符号十进制==

如果用%u打印负数,那么编译器会将该负数的二进制作为正数来对待,signed int 的取值范围-231到231-1,即-2147483648~2147483647,而unsigned int的表示范围为0到232-1,-1在内存中的二进制表示为11111111111111111111111111111111,对于无符号而言,第一位不再是符号位,就表示无符号整形最大值,故打印结果为4294967295。

%o 打印无符号八进制

%x %X打印大写或小写十六进制

仍然是无符号的

%f打印浮点数

在f前加上点(.)后边加数字,标识保留几位小数。

他会自动四舍五入。

保存位数还可以利用星号(*),格式如下(不常用,了解就行)

这种方法整形也可以使用,后边的3和6是要打印的宽度。

这里要知道,%f默认保留小数点后6位

如果想要获得更高的精度,就要制定其精度

%e %E科学计数法打印

只服务于浮点数,打印整形会出现未知的错误(数据错误)

%g过滤%f多余的0

%f默认保留小数点后6位,多余的0看着碍眼就可以直接使用%g打印,不用麻烦的控制宽度。

通过C++ Reference,可以看到%g的介绍是根据数字选择%f或者%e控制最短输出,并不输出多余的0,可以看到上边的例子选择的是%f的形式(且没有打印多余的0)

再看下边的例子

上边的数字用%f打印需要8位,%e只需要七位,下边数字%f只需要7位,而%e需要8位,对比下来是否非常明显?

%c打印字符类型

这个很简单。

对照ASCII表,97代表的就是字符a,如果用%c的形式打印,就会根据ASCII码表找到相应字符并打印。

%s打印字符窜

用%s打印,直接给一个字符指针就可以,编译器会自动识别然后帮你打印这个字符串。

%p打印传入变量地址

学过指针的都知道,指针保存的是什么,就是指向变量的地址,%p以十六进制打印指针。

配合取地址操作符进行使用(&),复习复习操作符?

%%打印%

用两个%来打印%,不然打印%时有可能会和后边的字符进行结合,编译器还以为他是标识符。

我就想打印heihei%c到显示器上,这样写他就报错,所以要用两个%

如图

%a%A十六进制输出浮点数

%a和%A时C99引入的格式化类型,以十六进制的形式打印浮点数。

2.5的二进制为0010 1000…,将对应的二进制右移一位首字母为1(一直都是1,如果是0110 1000,那就右移两位,保持第一位为1)

为什么用这么复杂的表示方法呢?像0.5,2.5这样的数全都可以精确表示出来,而0.15却不能精确表示,原因可见刷题笔记第二题。

用这种表示方法就可以较为精确的表示例如15.15。

解析如下

打印有颜色的字体

C语言中默认打印都是白色,有时候为了突出特定的信息,避免重要的警告或者错误的信息被其他大量打印的信息淹没,可以改变输出字体的颜色或者背景突出显示。

格式

1,printf(“\033[字体背景颜色,字体颜色m字符串\033[0m”)

以下是颜色对应数字

背景颜色 字体颜色
40:黑 30:黑
41:红 31:红
42:绿 32:绿
43:黄 33:黄
44:蓝 34:蓝
45:紫 35:紫
46:深绿 36:深绿
47:白 37:白

例如

本文到此结束,还有哪些需要补充的大家可以评论区发言哦。

目录
相关文章
|
4月前
|
存储 C语言
C语言数据类型、变量和运算符以及printf相关问题
C语言数据类型、变量和运算符以及printf相关问题
|
3月前
|
存储 C语言 数据格式
【C语言基础考研向】03混合运算和printf讲解
本文分为两部分。第一部分介绍了C语言中的混合运算与类型强制转换的重要性,通过实例展示了当整型数进行除法运算且结果为小数时,必须使用类型转换才能正确存储浮点数结果。第二部分详细讲解了`printf`函数的功能与使用方法,包括格式化输出不同类型数据的基本语法,并通过具体示例演示了如何利用字段宽度和对齐方式来控制输出格式,帮助读者更好地理解和掌握输出格式的控制技巧。
56 10
|
2月前
|
C语言
初识C语言:与计算机的交流之输入与输出(scanf和printf)
初识C语言:与计算机的交流之输入与输出(scanf和printf)
249 0
|
3月前
|
C语言
C语言程序设计核心详解 第三章:顺序结构,printf(),scanf()详解
本章介绍顺序结构的基本框架及C语言的标准输入输出。程序从`main()`开始依次执行,框架包括输入、计算和输出三部分。重点讲解了`printf()`与`scanf()`函数:`printf()`用于格式化输出,支持多种占位符;`scanf()`用于格式化输入,需注意普通字符与占位符的区别。此外还介绍了`putchar()`和`getchar()`函数,分别用于输出和接收单个字符。
|
4月前
|
存储 缓存 编译器
【C语言篇】scanf和printf万字超详细介绍(基本加拓展用法)(下篇)
scanf处理⽤⼾输⼊的原理是,⽤⼾的输⼊先放⼊缓存,等到按下回⻋键后,按照占位符对缓存进⾏解读。 解读⽤⼾输⼊时,会从上⼀次解读遗留的第⼀个字符开始,直到读完缓存,或者遇到第⼀个不符合条件的字符为⽌。
194 2
|
4月前
|
存储 C语言
【C语言篇】scanf和printf万字超详细介绍(基本加拓展用法)(上篇)
printf 的作⽤是将参数⽂本输出到屏幕。它名字⾥⾯的 f 代表 format (格式化),表⽰可以定制输出⽂本的格式。
94 1
|
5月前
|
C语言
C语言5 字符输出函数和格式输出函数
C语言5 字符输出函数和格式输出函数
103 1
|
5月前
|
存储 C语言
C语言6 字符串输入和格式输入函数
C语言6 字符串输入和格式输入函数
87 0
|
6月前
|
存储 C语言
C语言中的printf函数详解
C语言中的printf函数详解
224 0
|
6月前
|
C语言 C++
C语言printf()函数详解
C语言printf()函数详解