C语言中printf格式

合集下载

C语言中printf函数输出格式

C语言中printf函数输出格式

C语⾔中printf函数输出格式printf()函数是格式化输出函数, ⼀般⽤于向标准输出设备(例如屏幕)按规定格式输出信息。

⼀、Printf输出格式1、输出⼗进制整数int main(){//输出⼗进制整数%dprintf("输出的数字是:%d",666);return 0;}//结果是6662、输出⼋进制整数int main(){//输出⼋进制整数%oprintf("输出的数字是:%o",66);return 0;}//结果是1023、输出⼗六进制整数int main(){//输出⼗六进制整数%xprintf("输出的数字是:%x",66);return 0;}//结果是424、输出6位以上⼩数形式的实数(包括6位)int main(){//输出⼩数%fprintf("输出的数字是:%f",66.666);return 0;}//结果是66.6660005、输出5位以内⼩数形式的实数(包括5位)int main(){//输出⼩数%fprintf("输出的数字是:%f",66.666);return 0;}//结果是66.6666、输出指数形式的实数int main(){//输出指数%eprintf("输出的数字是:%e",6.6);return 0;}//结果是6.600000e+007、输出单个字符int main(){//输出单个字符%cprintf("输出的数字是:%c 或 %c",'a',97);return 0;}//结果是 a 或 a8、输出多个字符int main(){//输出多个字符%sprintf("输出的数字是:%s","owowo!");return 0;}//结果是 owowo!9、输出⾃定义位数int main(){//输出⾃定义位数,⽤“.数字”开头printf("输出的数字是:%.3d\n", 6);printf("输出的数字是:%.3f\n", 6.66666666);printf("输出的数字是:%.3f\n", 6.6);printf("输出的数字是:%.3s\n", "hahhahhahha");return 0;}//输出的数字是:006//输出的数字是:6.667//输出的数字是:6.600//输出的数字是:hah最后。

C语言输入输出函数printf与scanf的用法格式

C语言输入输出函数printf与scanf的用法格式

C 语言输入输出函数printf 与scanf 的用法格式printf()函数用来向标准输出设备(屏幕)写数据; scanf() 函数用来从标准输入设备(键盘)上读数据。

下面详细介绍这两个函数的用法。

一、printf()函数printf()函数是格式化输出函数, 一般用于向标准输出设备按规定格式输出信息。

在编写程序时经常会用到此函数。

printf()函数的调用格式为:printf("<格式化字符串>", <参量表>);其中格式化字符串包括两部分内容: 一部分是正常字符, 这些字符将按原样输出; 另一部分是格式控制字符, 以"%"开始, 后跟一个或几个控制字符,用来确定输出内容格式。

参量表是需要输出的一系列参数,可以是常量、变量或表达式,其个数必须与格式化字符串所说明的输出参数个数一样多, 各参数之间用","分开, 且顺序一一对应, 否则将会出现意想不到的错误。

例如:printf("a=%d b=%d",a,b);1. 格式控制符Turbo C2.0提供的格式化规定符如下: 格式控制字符参量表正常字符━━━━━━━━━━━━━━━━━━━━━━━━━━符号作用──────────────────────────%d 十进制有符号整数%u 十进制无符号整数%f 浮点数%s 字符串%c 单个字符%p 指针的值%e,%E 指数形式的浮点数%x, %X 无符号以十六进制表示的整数%o 无符号以八进制表示的整数%g,%G 自动选择合适的表示法━━━━━━━━━━━━━━━━━━━━━━━━━━printf的附加格式说明字符字符说明l 用于长整型数或双精度实型,可加在格式符d、o、x、u和f前面m(代表一个正整数据最小输出显示宽度数)n(代表一个正整数)对实数,表示输出n位小数;对字符串,表示截取的字符个数。

C语言的printf

C语言的printf

C语⾔的printf 格式printf(" "); //printf(格式串,表达式1,表达式2....);#include <stdio.h>#include <stdlib.h>void main(){int i,j;float x, y;i = 10;j = 20;x = 43.2583f;y = 5322.22f;printf("i=%d , j=%d , x=%f , y=%f\n",i,j,x,y);system("pause");}格式化字符串printfCode 格式%c 字符%d 带符号整数%i 带符号整数%e 科学计数法, 使⽤⼩写"e"%E 科学计数法, 使⽤⼤写"E"%f 浮点数%.1f 显⽰⼩数点后⼀位数字%m.pf或者 %-m.pf 其中m和p都是常数,m最⼩字符数量,p为保留⼩数点后⼏位,m是右对齐、-m是左对齐/*如果m⼤于所要显⽰的数值,则在前⾯加空格int x = 43;printf("%3d\n",x);printf("%5.3d\n",x); //占⽤5个字符,要有三个数字,不够⽤0来填充========================显⽰的是:*43,*为空格043*/%g 使⽤%e或%f中较短的⼀个%G 使⽤%E或%f中较短的⼀个%o ⼋进制%s ⼀串字符%u ⽆符号整数%x ⽆符号⼗六进制数, ⽤⼩写字母%X ⽆符号⼗六进制数, ⽤⼤写字母%p ⼀个指针%n 参数应该是⼀个指向⼀个整数的指针指向的是字符数放置的位置%% ⼀个'%'符号转义警报(蜂鸣器): \a回退符: \b换⾏符 : \n⽔平制表符: \tscanfscanf和scanf的区别scanf不会检查输⼊边界,容易造成内存溢出scanf_s会检查边界scanf中%d为⼗进制%i可以匹配⼗进制、⼋进制、⼗六进制。

C语言输入输出函数printf与scanf的用法格式

C语言输入输出函数printf与scanf的用法格式

C语言输入输出函数printf与scanf的用法格式C语言中的输入输出函数printf和scanf是我们在编程中经常用到的两个函数。

它们分别用于向屏幕输出数据和从键盘输入数据。

1.printf函数printf函数是C语言中用于输出的标准函数,其基本格式如下:printf("format string", argument);其中,format string是格式化字符串,它可以是任何你希望输出的文本或特定格式的文本,argument是你要输出的参数,可以是任何数据类型,例如int, float, double等。

例如,如果你想输出一个整数,你可以这样写:int x = 10;printf("The value of x is: %d", x);在这个例子中,%d是一个格式说明符,它表示一个整数。

在输出的时候,%d 会被x的值替换。

printf函数还支持许多其他类型的格式说明符,例如:•%f:浮点数•%c:字符•%s:字符串•%p:指针的值•%x:十六进制数等等。

你可以根据需要选择适合的类型。

2.scanf函数scanf函数是C语言中用于输入的标准函数,其基本格式如下:scanf("format string", argument);与printf类似,format string是格式化字符串,argument是你要输入的参数。

但是,scanf的格式说明符与printf略有不同。

例如,如果你想输入一个整数,你可以这样写:int x;scanf("%d", &x);在这个例子中,%d是一个格式说明符,它表示一个整数。

在输入的时候,你需要在%d前面输入一个数字,然后scanf会把这个数字存储到&x所指向的内存地址中。

注意,这里的&是取地址运算符,表示我们想要的是变量x的内存地址。

scanf函数还支持许多其他类型的格式说明符,例如:•%f:浮点数•%c:字符•%s:字符串(到第一个空格为止)•%p:指针的值•%x:十六进制数(必须以0x或0X开头)等等。

c语言printf用法

c语言printf用法

c语言printf用法C语言是一种常用的编程语言,常常被用来编写各种应用程序。

其中,printf是C语言中最常用的函数之一,它被用来将数据输出到控制台或者文本文件中。

本文将详细介绍C语言printf函数的用法及其参数。

一、printf函数概述printf是C语言中的一个函数,它被用来输出各种类型的数据。

它的基本用法为:printf("输出格式",输出数据);其中,输出格式可以包含转义序列和格式说明符,用来控制输出数据的格式。

输出数据可以是字符串、整数、浮点数等各种类型的数据。

二、转义序列转义序列是一种特殊的字符序列,用来表示一些特殊的字符或控制输出格式。

转义序列以反斜杠(\)开头,后面紧跟着一个或多个字符。

常见的转义序列如下表所示:转义序列含义\\ 反斜杠\' 单引号\" 双引号\b 回退符\n 换行符\r 回车符\t 制表符在输出字符串时,如果字符串中包含了双引号或单引号等特殊字符,可以用转义序列来表示。

例如:printf("Hello, \"world\"!\n");上述语句输出的结果是:其中,\"表示双引号,\n表示换行符。

三、格式说明符格式说明符含义%c 输出一个字符%d或%i 输出一个带符号的十进制整数 %u 输出一个无符号的十进制整数%o 输出一个八进制数%x或%X 输出一个十六进制数%f或%F 输出一个浮点数%e或%E 用科学计数法表示一个浮点数 %g或%G 根据实际情况选择%f或%e%s 输出一个字符串下面详细介绍各个格式说明符的用法:1、%c%c格式说明符用来输出一个字符。

例如: char ch = 'A';printf("%c\n", ch);A2、%d或%i-1233、%uunsigned int m = 456;printf("%u\n", m);4564、%o555、%x或%X%x或%X格式说明符用来输出一个十六进制数。

C语言中的格式输出与输入

C语言中的格式输出与输入

C语言中的格式输出与输入格式输入与输出:1.printf函数printf(格式控制,输出表列)例如:printf(“%d,%c\n”,I,c)括号里面包括两部分:(1)“格式控制”是用双撇号括起来的字符串:格式说明。

由%和格式字符组成,如%d、%f等,它的作用是将输出的数据转换为指定的格式输出。

普通字符。

即需要原样输出的字符。

例如上面printf函数中双撇号内的逗号、空格和换行符。

(2)“输出表列”是需要输出的一些数据,可以是表达式。

printf(“%d %d”,a,b)格式说明输出表列2.格式字符(1)d格式符。

用来输出十进制整数。

%d。

按十进制整形数据实际长度输出。

%md。

m是指定的输出字段的宽度。

如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。

%ld。

输出长整型数据(2)o格式符。

以八进制整数形式输出。

(3)x格式符。

以十六进制数形式输出整数。

(4)u格式符。

用来输出unsigned型数据,即无符号数,以十进制整数形式输出。

(5)c格式符。

用来输出一个字符。

(6)s格式符。

用来输出一个字符串。

%s 输出字符串%ms 输出的字符串占m列,字符长度大于m就全部输出。

小于m,则左补空格。

%-ms 同上,小于m时,则右补空格。

%m.ns 输出占m列,但只取字符串中左端n个字符。

这n个字符输出在m列的右侧,左补空格。

%-m.ns 这n个字符输出在m列的左侧,右补空格。

如果n>m,则m自动取n值。

(7)f格式符。

用来输出实数,以小数形式输出。

%f,不指定字段宽度,整数部分全部输出,并输出6位小数。

%m.nf,指定输出的数据共占m列,其中有n位小数。

如果数值长度小于m,则左端补空格。

%-m.nf, 同上,右端补空格。

(8)e格式发,以指数形式输出实数。

%e,不指定输出数据所占的宽度和数字部分的小数位数。

%m.ne n指输出的数据的小数部分(9)g格式,用来输出实数,它根据数值的大小,自动选f格式或e 格式,且不输出无意义的零。

c语言printf里面的格式

c语言printf里面的格式

c语言printf里面的格式
C语言中,printf函数是用来向屏幕或其他输出设备输出数据的函数。

它可以输出纯文本或者是数字、字符等数据类型,而且还可以通过格式化输出的方式,将数据以特定格式输出。

下面是printf函数中常用的格式控制字符:
1. %d:输出十进制整数。

2. %f:输出浮点数。

3. %c:输出一个字符。

4. %s:输出字符串。

5. %p:输出指针地址。

6. %x:输出十六进制整数。

7. %o:输出八进制整数。

8. %e:用科学计数法输出浮点数。

9. %g:根据数值大小自动选择%f或者%e输出浮点数。

10. %%:输出一个百分号。

另外,还有一些格式控制符的修饰符可用于控制输出的宽度、精度等,如下:
1. %nd:输出宽度为n的十进制整数,不足n位在左边补0。

2. %m.nf:输出宽度为m,精度为n的浮点数。

3. %-ns:输出宽度为n的左对齐字符串。

4. %*s:输出宽度为*的字符串,*由参数提供。

以上就是printf函数中常用的格式控制字符及其修饰符。

掌握
好这些内容可以使输出的结果更加符合要求,为程序的调试和开发提供便利。

c语言中printf的用法

c语言中printf的用法

c语言中printf的用法
printf() 是 C 语言中的输出函数之一,用于将指定的数据输出到屏幕或文件中。

它是一个非常常用的函数,可用于输出字符串、整数、浮点数等各种类型的数据。

在本篇文章中,我们将对 printf() 的用法做出详细的介绍。

1. printf() 函数的基本结构
```
printf(format, arg1, arg2, ...);
```
其中,format 是格式字符串,用于决定要输出的数据的类型、格式和排版方式;
arg1、arg2 等是要输出的数据,有一个或多个参数。

2. 常用的格式控制字符(format control character)
在格式字符串中,你可以使用不同的格式控制字符,以决定要输出的数据的类型和格式。

以下是一些常用的格式控制字符:
“%d”:用于输出十进制整数值。

“%c”:用于输出一个字符。

“%p”:用于输出指针类型变量的地址。

以上格式控制字符还带有许多其他的选项,比如精度、宽度等等,您可以通过在 % 后面附加数字和字母来指定。

例如 %5.2f 表示输出一个宽度为 5 位,精确到小数点后 2 位的浮点数值。

(1)输出一个字符串
输出一个字符串非常简单,只需要在格式字符串中使用 %s 格式控制字符并将字符串作为参数传递即可。

例如:
```
printf("Hello, World!\n");
```
上面的代码将会输出 a = 123。

(3)输出一个浮点数
上面的代码将会输出该指针变量的地址。

4. 总结。

c语言printf()输出格式大全

c语言printf()输出格式大全

c 语言printf() 输出格式大全1 •转换说明符" e.g. "% 6.2f"# :对c,s,d,u 类无影响;对o 类,在输出时加前缀o ;对x 类, 在输出时加前缀Ox ;对e,g,f类当结果有小数时才给出小数点。

3.格式字符串(格式)[标志][输出最少宽度][.精度][长度]类型 "%-md":左对齐,若m 比实际少时,按实际输出。

"%m.ns":输出m 位,取字符串(左起)n 位,左补空格,当n>m or m省略时m=ne.g."%7.2s"输%a(%A) 浮点数、十六进制数字和p-(P-)记数法(C99)%c 字符%d 有符号十进制整数%f 浮点数(包括float 和 doulbe)%e(%E) 浮点数指数输出[e-(E-)记数法]%g(%G) 浮点数不显无意义的零"0"%i 有符号十进制整数 (与%d 相同)%u 无符号十进制整数%o 八进制整g. 0123%x(%X) 十六进制整数0f(0F)e.g.0x1234%p 指针%s 字符串%% "%"左对齐: "-" e.g. "%-20s"右对齐:"+" e.g."%+20s"2.标志入CHINACH"输出%m.nf":输出浮点数,m为宽度,n为小数点右边数位e.g. "%3.1f"输入3852.99输出3853.0长度:为h短整形量,1为长整形量printf的格式控制的完整格式:% - 0 m.n I或h格式字符下面对组成格式说明的各项加以说明:①%表示格式说明的起始符号,不可缺少。

②-:有-表示左对齐输出,如省略表示右对齐输出。

③0:有0表示指定空位填0,如省略表示指定空位不填。

scanf printf的用法

scanf printf的用法

scanfprintf的用法
scanf和printf是C语言中的两个常用函数,用于输入和输出。

下面是它们的基本用法:
1. scanf函数:
-格式:scanf("格式字符串", 变量列表);
-作用:从标准输入(键盘)读取输入,并将输入的值存储到指定的变量中。

-示例:假设要读取一个整数,可以使用`scanf("%d", &num);`,其中`%d`表示读取一个整数,`&num`表示将读取的值存储到名为`num`的变量中。

2. printf函数:
-格式:printf("格式字符串", 参数列表);
-作用:将指定的值按照指定的格式输出到标准输出(终端)上。

-示例:假设要输出一个整数,可以使用`printf("%d", num);`,其中`%d`表示按整数格式输出变量`num`的值。

这里提供了非常基本的用法示例,实际应用中还可以使用更多的格式
说明符和转义序列来处理不同类型的数据和格式要求。

另外,请注意通过scanf读取字符串时要避免缓冲区溢出等问题,可以使用`fgets`函数来读取字符串并指定缓冲区的大小进行安全处理。

C语言printf输出格式

C语言printf输出格式

C语⾔printf输出格式printf的输出格式:printf 的格式printf 函数的原型为:# include <stdio.h>int printf(const char *format, ...);在讲每⼀个函数的时候都会先把它的函数原型写出来,这个原型你们现在看不懂不要紧,等到学完C语⾔之后再来看这个原型就会发现它是很有参考意义的!它对深刻理解函数有着很⼤的价值。

printf 的格式有四种:1) printf("字符串\n");1. # include <stdio.h>2. int main(void)3. {4. printf("Hello World!\n"); // \n表⽰换⾏5. return 0;6. }其中\n表⽰换⾏的意思。

它是⼀个转义字符,前⾯在讲字符常量的时候见过。

其中 n 是“new line”的缩写,即“新的⼀⾏”。

此外需要注意的是,printf 中的双引号和后⾯的分号必须是在英⽂输⼊法下。

双引号内的字符串可以是英⽂,也可以是中⽂。

2) printf("输出控制符",输出参数);1. # include <stdio.h>2. int main(void)3. {4. int i = 10;5. printf("%d\n", i); /*%d是输出控制符,d 表⽰⼗进制,后⾯的 i 是输出参数*/6. return 0;7. }这句话的意思是将变量 i 以⼗进制输出。

那么现在有⼀个问题:i 本⾝就是⼗进制,为什么还要将 i 以⼗进制输出呢?因为程序中虽然写的是 i=10,但是在内存中并不是将 10 这个⼗进制数存放进去,⽽是将 10 的⼆进制代码存放进去了。

计算机只能执⾏⼆进制 0、1 代码,⽽ 0、1 代码本⾝并没有什么实际的含义,它可以表⽰任何类型的数据。

c语言printf输出格式

c语言printf输出格式

c语言printf()输出格式大全1.转换说明符%a(%A) 浮点数、十六进制数字和p-(P-)记数法(C99)%c 字符%d 有符号十进制整数%f 浮点数(包括float和doulbe)%e(%E) 浮点数指数输出[e-(E-)记数法]%g(%G) 浮点数不显无意义的零"0"%i 有符号十进制整数(与%d相同)%u 无符号十进制整数%o 八进制整数 e.g. 0123%x(%X) 十六进制整数<?xml:namespace prefix = st1 />() e.g. 0x1234 %p 指针%s 字符串%% "%"2.标志左对齐:"-" e.g. "%-20s"右对齐:"+" e.g. "%+20s"空格:若符号为正,则显示空格,负则显示"-" e.g. "% "#:对c,s,d,u类无影响;对o类,在输出时加前缀o;对x类,在输出时加前缀0x;对e,g,f 类当结果有小数时才给出小数点。

3.格式字符串(格式)[标志][输出最少宽度][.精度][长度]类型"%-md" :左对齐,若m比实际少时,按实际输出。

"%m.ns":输出m位,取字符串(左起)n位,左补空格,当n>m or m省略时m=ne.g. "%7.2s" 输入CHINA输出" CH""%m.nf":输出浮点数,m为宽度,n为小数点右边数位e.g. "%" 输入3852.99输出3853.0长度:为h短整形量,l为长整形量printf的格式控制的完整格式:% - .n l或h 格式字符下面对组成格式说明的各项加以说明:①%:表示格式说明的起始符号,不可缺少。

c语言中的printf用法

c语言中的printf用法

c语言中的printf用法在C语言中,printf函数是一种非常重要的输出函数,它可以将格式化的数据输出到屏幕上。

接下来,我们将更深入地探讨printf函数的用法和特性。

1.函数原型首先,我们需要了解printf函数的原型声明:```cint printf(const char *format, ...);```参数说明:- format:格式化字符串,用于指定输出数据的格式。

- ...:可变参数列表,用于存储要输出的数据。

2.格式化字符串在format字符串中,可以使用各种格式说明符来表示不同的数据类型。

以下是一些常用的格式说明符:- %d:整数类型(int、short、long等)- %u:无符号整数类型(unsigned int、unsigned short、unsigned long等)- %f:浮点数类型(float、double等)- %c:字符类型(char)- %s:字符串类型- %x:十六进制整数类型(int、unsigned int等)- %X:大写十六进制整数类型(int、unsigned int等)- %%:百分号,表示占位符3.示例下面是一些使用printf函数的示例:```c#include <stdio.h>int main() {int a =10;float b =3.14;char c = 'A';char str[] = "Hello, World!";printf("整数:%d\n", a);printf("浮点数:%f\n", b);printf("字符:%c\n", c);printf("字符串:%s\n", str);return0;}```输出结果:```整数:10浮点数:3.140000字符:A字符串:Hello, World!```4.宽度修饰符printf函数还支持宽度修饰符,用于指定输出数据的宽度。

c 语言 printf中支持的格式

c 语言 printf中支持的格式

c 语言 printf中支持的格式在C语言中,printf函数是用于输出格式化的字符串到标准输出的函数。

它支持多种格式,这些格式可以用来输出不同类型的数据和满足不同的需求。

下面列举了printf函数中常用的一些格式:1.%d或%i:用于输出十进制整数。

例如:printf("%d", 10);输出:10。

2.%u:用于输出无符号十进制整数。

例如:printf("%u", 10);输出:10。

3.%f:用于输出浮点数。

例如:printf("%f", 3.14);输出:3.140000。

4.%s:用于输出字符串。

例如:printf("%s", "Hello, World!");输出:Hello, World!5.%c:用于输出字符。

例如:printf("%c", 'A');输出:A。

6.%p:用于输出指针的值。

例如:int x = 10; printf("%p", &x);输出:可能为类似0x7fffc5677b4c这样的地址值。

7.%x,%X:用于输出十六进制整数。

其中%x输出的十六进制数字中包含字母a-f,而%X输出的十六进制数字全为大写字母。

例如:printf("%x", 255);输出:ff。

8.%o:用于输出八进制整数。

例如:printf("%o", 255);输出:377。

9.%%:表示输出一个百分号。

例如:printf("%%");输出:%。

10.%-:表示输出的左对齐。

例如:printf("%-10d", 10);输出:10 (总共占10个字符宽度,左对齐)。

11.%+d或%+i:表示输出的十进制整数带有正负号。

例如:printf("%+d",10);输出:+10。

c语言printf里面的格式

c语言printf里面的格式

c语言printf里面的格式C语言的printf函数中,格式用于指定输出字符串的格式。

在printf函数中,格式字符串是用“%”开头的,每一个“%”后面紧跟一个转换字符。

下面我们分步骤阐述printf函数格式中常用的转换字符。

1. 打印字符型数据对于字符型数据,我们可以使用”%c”输出。

例如:char ch = 'a';printf("%c",ch);此时,输出结果为“a”。

2. 打印整型数据对于整型数据,我们可以使用”%d”输出十进制整数,使用”%u”输出十进制无符号整数,使用”%o”输出八进制整数,使用”%x”输出十六进制整数(小写字母),使用”%X”输出十六进制整数(大写字母)。

例如:int num = 10;printf("%d %u %o %x %X",num,num,num,num,num);此时,输出结果为“10 10 12 a A”。

3. 打印浮点型数据对于浮点型数据,我们可以使用”%f”输出,使用”%e”输出科学计数法表示的浮点数(小写字母),使用”%E”输出科学计数法表示的浮点数(大写字母)。

例如:float f = 3.14159;printf("%f %e %E",f,f,f);此时,输出结果为“3.141590 3.141590e+00 3.141590E+00”。

4. 打印字符串对于字符串类型的变量,我们可以使用”%s”打印。

例如:char str[] = "Hello, world!";printf("%s",str);此时,输出结果为“Hello, world!”。

5. 转换字符的位置和宽度对于转换字符,可以通过在转换字符前添加以下控制信息控制输出:a. 在“%”和转换字符之间添加一个“-”号,使其左对齐;b. 在“%”和转换字符之间添加数字,来控制输出宽度;c. 在输出宽度数字之后添加一个点和另一个数字,来控制精度。

C语言格式输出函数printf

C语言格式输出函数printf

C语言格式输出函数printf()详解标题4.1.1printf函数(格式输出函数)printf函数称为格式输出函数,其关键字最末一个字母f即为“格式”(format)之意。

其功能是按用户指定的格式,把指定的数据显示到显示器屏幕上。

在前面的例题中我们已多次使用过这个函数。

1.printf函数调用的一般形式printf函数是一个标准库函数,它的函数原型在头文件“stdio.h”中。

但作为一个特例,不要求在使用printf函数之前必须包含stdio.h文件。

printf函数调用的一般形式为:printf(“格式控制字符串”,输出表列)其中格式控制字符串用于指定输出格式。

格式控制串可由格式字符串和非格式字符串两种组成。

格式字符串是以%开头的字符串,在%后面跟有各种格式字符,以说明输出数据的类型、形式、长度、小数位数等。

如:“%d”表示按十进制整型输出;“%ld”表示按十进制长整型输出;“%c”表示按字符型输出等。

非格式字符串在输出时原样照印,在显示中起提示作用。

输出表列中给出了各个输出项,要求格式字符串和各输出项在数量和类型上应该一一对应。

【例4.3】main(){int a=88,b=89;printf("%d%d\n",a,b);printf("%d,%d\n",a,b);printf("%c,%c\n",a,b);printf("a=%d,b=%d",a,b);}本例中四次输出了a,b的值,但由于格式控制串不同,输出的结果也不相同。

第四行的输出语句格式控制串中,两格式串%d之间加了一个空格(非格式字符),所以输出的a,b值之间有一个空格。

第五行的printf语句格式控制串中加入的是非格式字符逗号,因此输出的a,b值之间加了一个逗号。

第六行的格式串要求按字符型输出a,b值。

第七行中为了提示输出结果又增加了非格式字符串。

C语言printf函数

C语言printf函数

C语言printf函数一、printf函数的一般调用形式功能:printf函数用于输出信息。

格式:printf(格式控制,输出项1,输出项2,……)说明:格式控制是字符串形式,输出项是要输出的字符或变量名。

在printf函数的调用之后加上“;”,则构成输出语句。

例如:printf(“a=%d,b=%d”,a,b); 语句,其中,printf是函数名;“a=%d,b=%d”是输出格式控制,决定了输出数据的内容和格式;a、b称为输出项,是printf函数的实参。

二、printf函数中常用的格式说明格式控制中,每个格式说明都必须用“%”开头,以一个格式字符作为结束,在此之间可以根据需要插入“宽度说明”、左对齐符号“-”、前导零符号“0”等。

A:格式字符:主要用于说明输出字符的格式;B:长度修饰符:在“%”和格式字符之间可以加入长度修饰符,以保证数据输出格式的正确和对齐;C:输出数据所占的宽度说明:当使用%d、%c、%f、%e、%s等的格式说明时,输出数据所占的宽度由系统决定,通常按照数据本身的实际宽度输出,前后不加空格,并采用右对齐的形式;D:输出数据左对齐:输出数据都默认为右对齐,若想左对齐,可以在格式控制中的%与格式字符之间加一个“-”来实现;E:使输出数据总带“+”和“-”:通常输出的数据如果是负数,前面有“-”,但正数前面的“+”一般都省略了,如果想让每一个数前面都带正负号,可以在“%”和格式字符之间加一个“+”来实现。

三、使用printf函数时的注意事项1:printf的输出格式为自由格式,是否在两个数之间留逗号、空格、或回车,完全取决于格式控制;2:格式控制中必须含有与输出项一一对应到输出格式说明,类型必须匹配,若格式说明与输出项的类型不一一对应匹配,则不能正确输出,而且编译时不会报错。

若格式说明个数少于输出项个数,则多余的输出项不予输出;若格式说明的个数多于输出项的个数,则将输出一些无意义的数字乱码;3:在格式控制中,除了前面要求的输出格式,还可以包括任意的合法字符(包括汉字和转义字符),这些字符输出时将原样输出,此外还可以利用\n(换行)、\r(回车)、\t(制表)、\a(响铃)等控制输出格式;4:如果要输出%,可以在格式控制中用“%%”表示,将输出一个%;5:printf函数有返回值,返回值是本次调用输出字符的个数,包括回车等控制符。

C语言的printf输出格式控制

C语言的printf输出格式控制

C语⾔的printf输出格式控制C语⾔的printf输出格式控制printf⼤家都⽿熟能详,但是能真正将其⽤法弄透的估计很少见。

转⼀篇,改天整理。

1.转换说明符%a(%A) 浮点数、⼗六进制数字和p-(P-)记数法(C99)%c 字符%d 有符号⼗进制整数%f 浮点数(包括float和doulbe)%e(%E) 浮点数指数输出[e-(E-)记数法]%g(%G) 浮点数不显⽆意义的零"0"%i 有符号⼗进制整数(与%d相同)%u ⽆符号⼗进制整数 %o ⼋进制整数%x(%X) ⼗六进制整数0f(0F) e.g. 0x1234%p 指针%s 字符串%% 输出字符%2.标志左对齐:"-" ⽐如:"%-20s"右对齐:"+" ⽐如:"%+20s"空格:若符号为正,则显⽰空格,负则显⽰"-" ⽐如:"% 6.2f"#:对c,s,d,u类⽆影响;对o类,在输出时加前缀o;对x类,在输出时加前缀0x;对e,g,f 类当结果有⼩数时才给出⼩数点。

printf的格式控制的完整格式:% - 0 m.n l或h 格式字符下⾯对组成格式说明的各项加以说明:①%:表⽰格式说明的起始符号,不可缺少。

②-:有-表⽰左对齐输出,如省略表⽰右对齐输出。

③0:有0表⽰指定空位填0,如省略表⽰指定空位不填。

④m.n:m指域宽,即对应的输出项在输出设备上所占的字符数。

N指精度。

⽤于说明输出的实型数的⼩数位数。

未指定n时,隐含的精度为n=6位。

⑤l或h:l对整型指long型,对实型指double型。

h⽤于将整型的格式字符修正为short型。

格式字符格式字符⽤以指定输出项的数据类型和输出格式。

①d格式:⽤来输出⼗进制整数。

有以下⼏种⽤法:%d:按整型数据的实际长度输出。

%md:m为指定的输出字段的宽度。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

2009-05-03 10:55Turbo C2.0 标准库提供了两个控制台格式化输入、输出函数printf( ) 和scanf(), 这两个函数可以在标准输入输出设备上以各种不同的格式读写数据。

printf()函数用来向标准输出设备(屏幕)写数据; scanf() 函数用来从标准输入设备(键盘)上读数据。

下面详细介绍这两个函数的用法。

一、printf()函数printf()函数是格式化输出函数, 一般用于向标准输出设备按规定格式输出信息。

在编写程序时经常会用到此函数。

printf()函数的调用格式为:printf("<格式化字符串>", <参量表>);其中格式化字符串包括两部分内容: 一部分是正常字符, 这些字符将按原样输出; 另一部分是格式化规定字符, 以"%"开始, 后跟一个或几个规定字符,用来确定输出内容格式。

参量表是需要输出的一系列参数, 其个数必须与格式化字符串所说明的输出参数个数一样多, 各参数之间用","分开, 且顺序一一对应, 否则将会出现意想不到的错误。

1. 格式化规定符Turbo C2.0提供的格式化规定符如下:━━━━━━━━━━━━━━━━━━━━━━━━━━符号作用──────────────────────────%d 十进制有符号整数%u 十进制无符号整数%f 浮点数%s 字符串%c 单个字符%p 指针的值%e 指数形式的浮点数%x, %X 无符号以十六进制表示的整数%0 无符号以八进制表示的整数%g 自动选择合适的表示法━━━━━━━━━━━━━━━━━━━━━━━━━━说明:(1). 可以在"%"和字母之间插进数字表示最大场宽。

例如: %3d 表示输出3位整型数, 不够3位右对齐。

%9.2f 表示输出场宽为9的浮点数, 其中小数位为2, 整数位为6,小数点占一位, 不够9位右对齐。

%8s 表示输出8个字符的字符串, 不够8个字符右对齐。

如果字符串的长度、或整型数位数超过说明的场宽, 将按其实际长度输出。

但对浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出; 若小数部分位数超过了说明的小数位宽度, 则按说明的宽度以四舍五入输出。

另外, 若想在输出值前加一些0, 就应在场宽项前加个0。

例如: %04d 表示在输出一个小于4位的数值时, 将在前面补0使其总宽度为4位。

如果用浮点数表示字符或整型量的输出格式, 小数点后的数字代表最大宽度,小数点前的数字代表最小宽度。

例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。

若大于9, 则第9个字符以后的内容将被删除。

(2). 可以在"%"和字母之间加小写字母l, 表示输出的是长型数。

例如: %ld 表示输出long整数%lf 表示输出double浮点数(3). 可以控制输出左对齐或右对齐, 即在"%"和字母之间加入一个"-" 号可说明输出为左对齐, 否则为右对齐。

例如: %-7d 表示输出7位整数左对齐%-10s 表示输出10个字符左对齐2. 一些特殊规定字符━━━━━━━━━━━━━━━━━━━━━━━━━━字符作用──────────────────────────\n 换行\f 清屏并换页\r 回车\t Tab符\xhh 表示一个ASCII码用16进表示,其中hh是1到2个16进制数━━━━━━━━━━━━━━━━━━━━━━━━━━由本节所学的printf()函数, 并结合上一节学习的数据类型, 编制下面的程序, 以加深对Turbo C2.0数据类型的了解。

例1#include<stdio.h>#include<string.h>int main(){char c, s[20], *p;int a=1234, *i;float f=3.141592653589;double x=0.12345678987654321;p="How do you do";strcpy(s, "Hello, Comrade");*i=12;c='\x41';printf("a=%d\n", a); /*结果输出十进制整数a=1234*/printf("a=%6d\n", a); /*结果输出6位十进制数a= 1234*/printf("a=%06d\n", a); /*结果输出6位十进制数a=001234*/ printf("a=%2d\n", a); /*a超过2位, 按实际值输出a=1234*/ printf("*i=%4d\n", *i); /*输出4位十进制整数*i= 12*/printf("*i=%-4d\n", *i); /*输出左对齐4位十进制整数*i=12*/ printf("i=%p\n", i); /*输出地址i=06E4*/printf("f=%f\n", f); /*输出浮点数f=3.141593*/printf("f=6.4f\n", f); /*输出6位其中小数点后4位的浮点数f=3.1416*/printf("x=%lf\n", x); /*输出长浮点数x=0.123457*/printf("x=%18.16lf\n", x);/*输出18位其中小数点后16位的长浮点数x=0.1234567898765432*/printf("c=%c\n", c); /*输出字符c=A*/printf("c=%x\n", c); /*输出字符的ASCII码值c=41*/printf("s[]=%s\n", s); /*输出数组字符串s[]=Hello, Comrade*/printf("s[]=%6.9s\n", s);/*输出最多9个字符的字符串s[]=Hello,Co*/printf("s=%p\n", s); /*输出数组字符串首字符地址s=FFBE*/ printf("*p=%s\n", p); /* 输出指针字符串p=How do you do*/ printf("p=%p\n", p); /*输出指针的值p=0194*/getch();retunr 0;}上面结果中的地址值在不同计算机上可能不同。

例1.中第一条语句#include<stdio.h>的含义是调用另一个文件stdio.h,这是一个头文件, 其中包括全部标准输入输出库函数的数据类型定义和函数说明。

Turbo C2.0对每个库函数便用的变量及函数类型都已作了定义与说明, 放在相应头文件"*.h"中, 用户用到这些函数时必须要用#include<*.h>或#include"*. h" 语句调用相应的头文件, 以供连接。

若没有用此语句说明, 则连接时将会出现错误。

二、scanf()函数scanf()函数是格式化输入函数, 它从标准输入设备(键盘) 读取输入的信息。

其调用格式为:scanf("<格式化字符串>", <地址表>);格式化字符串包括以下三类不同的字符;1. 格式化说明符: 格式化说明符与printf()函数中的格式说明符基本相同。

2. 空白字符: 空白字符会使scanf()函数在读操作中略去输入中的一个或多个空白字符。

3. 非空白字符: 一个非空白字符会使scanf()函数在读入时剔除掉与这个非空白字符相同的字符。

地址表是需要读入的所有变量的地址, 而不是变量本身。

这与printf()函数完全不同, 要特别注意。

各个变量的地址之间同","分开。

例2:main(){int i, j;printf("i, j=?\n");scanf("%d, %d", &i, &j);}上例中的scanf()函数先读一个整型数, 然后把接着输入的逗号剔除掉,最后读入另一个整型数。

如果","这一特定字符没有找到, scanf()函数就终止。

若参数之间的分隔符为空格, 则参数之间必须输入一个或多个空格。

说明:(1). 对于字符串数组或字符串指针变量, 由于数组名和指针变量名本身就是地址, 因此使用scanf()函数时, 不需要在它们前面加上"&"操作符。

例3mian(){char *p, str[20];scanf("%s", p); /*从健盘输入字符串*/scanf("%s", str);printf("%s\n", p); /*向屏幕输出字符串*/printf("%s\n", str);}(2). 可以在格式化字符串中的"%"各格式化规定符之间加入一个整数, 表示任何读操作中的最大位数。

如例3中若规定只能输入10字符给字符串指针p, 则第一条scanf() 函数语句变为scanf("%10s", p);程序运行时一旦输入字符个数大于10, p就不再继续读入, 而后面的一个读入函数即scanf("%s", str)就会从第11个字符开始读入。

实际使用scanf()函数时存在一个问题, 下面举例进行说明:当使用多个scanf()函数连续给多个字符变量输入时, 例如:main(){char c1, c2;scanf("%c", &c1);scanf("%c", &c2);printf("c1 is %c, c2 is %c", c2\1, c2);}运行该程序, 输入一个字符A后回车 (要完成输入必须回车), 在执行scanf ("%c", &c1)时, 给变量c1赋值"A", 但回车符仍然留在缓冲区内, 执行输入语句 scanf("%c", &c2)时, 变量c2输出的是一空行, 如果输入AB后回车,那么输出结果为: c1 is A, c2 is B。

相关文档
最新文档