C语言输出格式

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

参量表是需要输出的一系列参数, 其个数必须与格式化字符串所说明的输出参数个数一样多, 各参数之间用","分开, 且顺序一一对应, 否则将会出现意想不到的错误。/*******************************************************************/printf的格式控制的完整格式:%  -  0  m.n  l或h  格式字符下面对组成格式说明的各项加以说明:①%:表示格式说明的起始符号,不可缺少。②-:有-表示左对齐输出,如省略表示右对齐输出。③0:有0表示指定空位填0,如省略表示指定空位不填。④m.n:m指域宽,即对应的输出项在输出设备上所占的字符数。       n指精度,用于说明输出的实型数的小数位数。为指定n时,隐含的精度为n=6位。⑤l或h:l对整型指long型,对实型指double型。h用于将整型的格式字符修正为short型。

格式小结:(1)最常用的格式是%d,含义是以10进制形式打印一个整数。如果输出的整数是负数,则输出的第一个字符就是-号。%d:按整型数据的实际长度输出。%md:m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。%ld:输出长整型数据。

(2)%u格式与%d格式类似,只不过要求打印无符号10进制整数。以无符号十进制形式输出整数。对长整型可以用"%lu"格式输出。同样也可以指定字段宽度用“%mu”格式输出。

(3)%o格式请求输出8进制整数,以无符号八进制形式输出整数。对长整型可以用"%lo"格式输出。同样也可以指定字段宽度用“%mo”格式输出。

(4)%x和%X格式请求输出16进制整数。%x格式中用小写字母a,b,c,d,e,f来表示10到15之间的数,以无符号十六进制形式输出整数。对长整型可以用"%lx"格式输出。同样也可以指定字段宽度用"%mx"格式输出。%X格式中用大写字母A,B,C,D,E,F来表示10到15之间的数共同点:8进制和16进制整数总是作为无符号数处理的。

(5)%s格式用于打印字符串,与之对应的参数应该是一个字符指针,待输出的字符始于该指针所指向的地址,直到出现一个空字符(‘\0‘)才终止。%s:例如:printf("%s", "CHINA")输出"CHINA"字符串(不包括双引号)。%ms:输出的字符串占m列,如字符串本身长度大于m,则突破获m的限制,将字符串全部输出。若串长小于m,则左补空格。%-ms:如果串长小于m,则在m列范围内,字符串向左靠,右补空格。%m.ns:输出占m列,但只取字符串中左端n个字符。这n个字符输出在m列的右侧,左补空格。%-m.ns:其中m、n含义同上,n个字符输出在m列范围的左侧,右补空格。如果n>m,则自动取n值,即保证n个字符正常输出。

(6)%c格式用于打印单个字符:例如:printf("%c",c); 等价于 putchar(c);

(7)%g,%f和%e这三个格式用于打印浮点值。%g格式用于打印那些不需要按列对齐的浮点数特别有用。其作用有二:一,去掉该数尾多余的零(没有达到六位的数)二,保留六位有效数字(多余六位的)%e格式用于打印浮点数时,一律显示地使用指数形式:例如:输出圆周率时是:3.141593e+00两者的区别:%g格式打印出的数是总共6位有效数字%e格式打印出小数点后的6位有效数字%f禁止使用指数形式来表示浮点数。因此圆周率输出为:3.141593(但注意它的精度要求:也是小数点后6位有效数字)(8)%%格式用于打印一个%字符。

(9)%E和%G只是在输出时用大写字母(E)代替了小写字母(e)⑦f格式:用来输出实数(包括单、双精度),以小数形式输出。有以下几种用法:%f:不指定宽度,整数部分全部输出并输出6位小数。%m.nf:输出共占m列,其中有n位小数,如数值宽度小于m左端补空格。 %-m.nf:输出共占n列,其中有n位小数,如数值宽度小于m右端补空格。⑧e格式:以指数形式输出实数。可用以下形式:%e:数字部分(又称尾数)输出6位小数,指数部分占5位或4位。%m.ne和%-m.ne:m、n和”-”字符含义与前相同。此处n指数据的数字部分的小数位数,m表示整个输出数据所占的宽度。⑨g格式:自动选f格式或e格式中较短的一种输出,且不输出无意义的零。/*******************************************************************/unsigned int i=295;printf("%d\n",i);295Press any key to continue

(1). 可以在"%"和字母之间插进数字表示最大场宽。例如: %2d 表示输出3位整型数, 不够2位右对齐。例如: %5d 表示输出3位整型数, 不够5位右对齐。例如: %10d 表示输出3位整型数, 不够10位右对齐。unsigned int i=295;printf("%2d\n",i);printf("%5d\n",i);printf("%10d\n",i);295  295       295Press any key to continue(2).补0或者其它例如: %02d 表示输出3位整型数, 不够2位右对齐,补0。例如: %05d 表示输出3位整型数, 不够5位右对齐,补0。例如: %010d 表示输出3位整型数, 不够10位右对齐,补0。unsigned int i=295;printf("%02d\n",i);printf("%05d\n",i);printf("%010d\n",i);295002950000000295Press any key to continue(3).负数int i=-295;printf("%02d\n",i);printf("%05d\n",i);printf("%010d\n",i);-295-0295-000000295Press any key to continue

(4). 可以控制输出左对齐或右对齐, 即在"%"和字母之间加入一个"-" 号可 说明输出为左对齐, 否则为右对齐。 unsigned int i=295;printf("%-02d\n",i);printf("%-05d\n",i);printf("%-010d\n",i);295295295Press any key to continue

(5). 可以在"%"和字母之间加小写字母l, 表示输出的是长型数。 例如: %ld 表示输出long整数 %lf 表示输出double浮点数 

(6).%9.2f 表示输出场宽为9的浮点数, 其中小数位为2, 整数位为6, 小数点占一位, 不够9位右对齐。 例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9, 则 第9个字符以后的内容将被删除./*unsigned int i=295;printf("%d\n",i);printf("%1d\n",i);printf("%09d\n",i);printf("%09d\n",(unsigned char)i);printf("%9d\n",(unsigned char)i);printf("%-9d\n",(unsigned char)i);*//*295295000000295000000039       3939Press any key to continue*//*******************************************************************/对于m.n的格式还可以用如下方法表示(例)int m=10,n=5; char ch[]="abcdefghijklmnopqrst"; printf("%*.*s\n",m,n,ch);//输出为     abcde前边的*定义的是总的宽度,后边的定义的是输出的个数,分别对应外面的参数m和n。我想这种方法的好处是可以在语句之外对参数m和n赋值,从而控制输出格式/*******************************************************************/"%08lx\n",4byte"%04x\n",2byte"%-2.2BX",1byte
时间: 2024-10-22 02:19:21

C语言输出格式的相关文章

C语言输出格式总结(转)

C语言输出格式总结 本文转自 静沙 的博客.因为文章很难找到,所以记作随笔. 1 一般格式 printf(格式控制,输出表列) 例如:printf("i=%d,ch=%c\n",i,ch); 说明: (1)“格式控制”是用双撇号括起来的字符串,也称“转换控制字符串”,它包括两种信息: ①格式说明:由“%”和格式字符组成,它的作用是将输出的数据转换为指定的格式输出. ②普通字符,即需要原样输出的字符. (2)“输出表列”是需要输出的一些数据,可以是表达式 (3) printf函数的一般形

C语言----输出格式和基本运算

(1)C语言求绝对值的函数是abs,在头文件<stdlib.h>里,求浮点数据绝对值时,用函数fabs,在头文件<math.h>中. #include<stdio.h> #include<stdlib.h> #include<math.h> int main (){ int a; float b; scanf("%d %f",&a,&b); printf("%d\n",abs(a));//求

C语言输出格式总结

1 一般格式 printf(格式控制,输出表列) 例如:printf("i=%d,ch=%c\n",i,ch); 说明: (1)"格式控制"是用双撇号括起来的字符串,也称"转换控制字符串",它包括两种信息: ①格式说明:由"%"和格式字符组成,它的作用是将输出的数据转换为指定的格式输出. ②普通字符,即需要原样输出的字符. (2)"输出表列"是需要输出的一些数据,可以是表达式 (3) printf函数的一般

C语言scanf输入格式 printf输出格式

对于刚接触C语言的同学来说 可能会遇到这个问题 因为博主也是个菜鸟经常因为搞不清楚单精度双精度还有输入输出格式的问题 就这个问题也百度的很多次 所以在这里总结一下分享给大家 printf输出格式 1.转换说明符       %a(%A)     浮点数.十六进制数字和p-(P-)记数法(C99)       %c             字符       %d             有符号十进制整数       %f              浮点数(包括float和doulbe)      

从C中变化过来的各种语言的printf输出格式

在c.php和shell中经常可以碰到printf的使用,特别是在php中printf的相关变种有好几个:print.printf.sprintf.vprintf.vsprintf 在这些语言中,printf基本上都是格式化输出字符串,而且基本都是在C的基础上演变来的,下面就以php中的这些做个记录 虽然php中有这么多,但是其中他们的差别相对来说比较小 1.print print “hello php”或 php(“hello php”) print 只是一个语言结构,并不是一个函数,就类似于

C语言中输入输出格式控制

1.C语言中,非零值为真,真用1表示:零值为假,假用0表示. 2.转义字符参考: \a 蜂鸣,响铃 \b 回退:向后退一格 \f 换页 \n 换行 \r 回车,光标到本行行首 \t 水平制表 \v 垂直制表 \\ 反斜杠 \' 单引号 \" 双引号 \? 问号 \ddd 三位八进制 \0 空字符(NULL),什么都不做 \xhh 二位十六进制 说明: 1)\v垂直制表和\f换页符对屏幕没有任何影响,但会影响打印机执行响应操作. 2),\n其实应该叫回车换行.换行只是换一行,不改变光标的横坐标:回

C语言的printf输出格式控制

printf大家都耳熟能详,但是能真正将其用法弄透的估计很少见. 转一篇,改天整理. 1.转换说明符 %a(%A)     浮点数.十六进制数字和p-(P-)记数法(C99) %c         字符 %d         有符号十进制整数 %f         浮点数(包括float和doulbe) %e(%E)     浮点数指数输出[e-(E-)记数法] %g(%G)     浮点数不显无意义的零"0" %i         有符号十进制整数(与%d相同) %u        

C语言的一些输出格式

%e      printf()的一种输出格式 科学表示的一种浮点数 1.24==1.240000e+000 1240000==1.240000e+006                        指数不得超过3位数 0.00124==1.240000e-003 %g printf()的一个输出格式类型,它表示以%f,%e中较短的输出宽度输出单.双精度实数,在指数小于-4或者大于等于精度时使用%e格式 (%g用于打印浮点型数据时,会去掉多余的零,至多保留六位有效数字(不同于%e的默认保留小数

c语言中输入输出格式的控制

一.输入格式的控制 scanf函数中格式字符: (1)d,i:用来输入有符号的十进制中 (2) u:用来输入无符号的十进制整数 (3)o:用来输入无符号的八进制整数 (4)x,X:用来输入无符号的十六进制整数(大小写作用相同) (5)c:用来输入单个符号 (6) s:用来输入字符串,将字符串送到一个字符数组中,在输入时以非空白字符开始,以第一个空白 字符结束.字符串以串结束标志'\0'作为其最后一个字符 (7)f:用来输入实数,可以用小数形式或者指数形式输入 (8)e,E,g,G:与f作用相同,