C语言输出附加格式说明字符怎么用

供稿:hz-xin.com     日期:2025-01-13
请分别说明c语言中输入、输出格式字符串的特点与作用。

格式说明由“%”和格式字符组成,如%d%f等。它的作用是将输出的数据转换为指定的格式输出。格式说明总是由“%”字符开始的。不同类型的数据用不同的格式字符。 格式字符有d,o,x,u,c,s,f,e,g等。 如%d整型输入/输出,%ld长整型输入/输出,%o以八进制数形式输入/输出整数,%x以十六进制数形式输入/输出整数,%u以十进制数输入/输出unsigned型数据(无符号数)。%c用来输入/输出一个字符,%s用来输入/输出一个字符串,%f用来输入/输出实数,以小数形式输出,(备注:浮点数是不能定义输入的精度的,所以,scanf(“%6.2f”,&a)这种写法是“错误的”!!!)%e以指数形式输出实数,%g根据大小自动选f格式或e格式,且不输出无意义的零。scanf(控制字符,地址列表) 格式字符的含义同printf函数,地址列表是由若干个地址组成的表列,可以是变量的地址,或字符串的首地址。如scanf("%d%c%s",&a,&b,str)

  c语言中的格式说明符,以%开头,后面接上字母,如%d表示整数,%f表示浮点数,%s表示字符串,%c表示字符等等!


  扩展:格式说明符详细说明

  ① d格式:用来输出十进制整数。有以下几种用法:
  %d:按整型数据十进制的实际长度输出。
  %md:m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。
  %ld:输出长整型数据。

  ② o格式:以无符号八进制形式输出整数。
  %d:按整型数据八进制的实际长度输出。
  %lo:对长整型可以用格式输出
  %mo:指定字段宽度用格式输出

  ③ x格式:以无符号十六进制形式输出整数。
  %x:按整型数据十六进制的实际长度输出。
  %lx:对长整型可以用格式输出
  %mx:指定字段宽度用格式输出

  ④ u格式:以无符号十进制形式输出整数。
  %u:按无符号整型数据十进制的实际长度输出。
  %lu:对长整型可以用格式输出
  %mu:指定字段宽度用格式输出

  ⑤ c格式:输出一个字符。
  ⑥ s格式:用来输出一个串。有几中用法
  %s:例如:printf("%s", "CHINA")输出"CHINA"字符串(不包括双引号)。
  %ms:输出的字符串占m列,如字符串长度大于m,将字符串全部输出。若串长小于m,则左补空格。
  %-ms:如果串长小于m,则在m列范围内,字符串向左靠,右补空格。
  %m.ns:输出占m列,但只取字符串中左端n个字符。这n个字符输出在m列的右侧,左补空格。
  %-m.ns:其中m、n含义同上,n个字符输出在m列范围的左侧,右补空格。如果n>m,则自动取n值,即保证n个字符正常输出。

  ⑦ 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表示整个输出数据所占的宽度。

  ⑨ p格式:输出指针地址

C语言基本的输出格式说明符如下:

%d 十进制有符号整数 

%u 十进制无符号整数 

%f 浮点数 

%s 字符串 

%c 单个字符 

%p 指针的值 

%e 指数形式的浮点数 

%x, %X 无符号以十六进制表示的整数 

%0 无符号以八进制表示的整数 

%g 自动选择合适的表示法 


说明: 

1、可以在"%"和字母之间插进数字表示最大场宽。 例如:

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

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

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

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

但对浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出; 

若小数部分位数超过了说明的小数位宽度, 则按说明的宽度以四舍五入输出。 


2、 可以在"%"和字母之间加小写字母l, 表示输出的是长型数。 例如:

%ld 表示输出long整数 

%lf 表示输出double浮点数 


3、可以控制输出左对齐或右对齐, 即在"%"和字母之间加入一个"-" 号可说明输出为左对齐, 否则为右对齐。 例如:

%-7d 表示输出7位整数左对齐 

%-10s 表示输出10个字符左对齐


使用方法可以参考如下程序:

#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
", a); /*结果输出十进制整数a=1234*/ 
    printf("a=%6d
", a); /*结果输出6位十进制数a= 1234*/ 
    printf("a=%06d
", a); /*结果输出6位十进制数a=001234*/ 
    printf("a=%2d
", a); /*a超过2位, 按实际值输出a=1234*/ 
    printf("*i=%4d
", *i); /*输出4位十进制整数*i= 12*/ 
    printf("*i=%-4d
", *i); /*输出左对齐4位十进制整数*i=12*/ 
    printf("i=%p
", i); /*输出地址i=06E4*/ 
    printf("f=%f
", f); /*输出浮点数f=3.141593*/ 
    printf("f=6.4f
", f); /*输出6位其中小数点后4位的浮点数f=3.1416*/ 
    printf("x=%lf
", x); /*输出长浮点数x=0.123457*/ 
    printf("x=%18.16lf
", x);/*输出18位其中小数点后16位的长浮点数x=0.1234567898765432*/ 
    printf("c=%c
", c); /*输出字符c=A*/ 
    printf("c=%x
", c); /*输出字符的ASCII码值c=41*/ 
    printf("s[]=%s
", s); /*输出数组字符串s[]=Hello, Comrade*/ 
    printf("s[]=%6.9s
", s);/*输出最多9个字符的字符串s[]=Hello, Co*/ 
    printf("s=%p
", s); /*输出数组字符串首字符地址s=FFBE*/ 
    printf("*p=%s
", p); /* 输出指针字符串p=How do you do*/ 
    printf("p=%p
", p); /*输出指针的值p=0194*/ 
    getch(); 
    retunr 0; 
}


1.%msd。m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出,例如:
printf("%4d,%4d",a,b);
若a=123,b=12345,则输出结果为
_123,12345
2.%ms,输出的字符串占m列,如果本身长度大于m,则突破m的限制,将字符串全部输出。若串长度小于m,则左补空格。
3.%-ms,如果串长度小于m,则在m列范围内,字符串向左靠,右补空格。
4.%m.ns,输出占m列,但只取字符串左端n个字符。这n个字符输出在m列的右侧,左补空格。
5.%-m.ns,其中m、n含义同上,n个字符输出在m列范围的左侧,右补空格。如果n>m,则m自动取n值,即保证n个字符正常输出。例如:
printf("%7.2s,%-5.3s\n","CHINA","CHINA");
则输出结果为
_ _ _ _ _ CH,CHI _ _

这个,举个例子吧:
int a=1000;
printf("%5d",a);
m和.n都是用在%号跟类型之间的,如果数值长度大于m会根据实际输出,不足则又对齐
float a=1.23456
printf("%.3f",a);就是指显示小数点后3位,4舍5入

C语言 printf详解
printf函数的格式控制非常灵活,可以控制输出的对齐、填充字符、宽度和精度。例如,"%-5d"表示左对齐的5位整数,而"%05d"则会在不足5位时用0填充。对字符和字符串,还有各种格式说明如"%m.ns",用于指定输出的字符数和对齐方式。理解并熟练使用printf的格式控制是C语言编程中的重要技能,它能帮助你...

(C语言)unsigned long类型变量输出时,格式转换说明符应如何定义?_百度...
需要准备的材料分别有:电脑、C语言编译器。1、首先,打开C语言编译器,新建一个初始.cpp文件,例如:test.cpp。2、在test.cpp文件中,输入C语言代码:unsigned long a = 1024;printf("%u", a);。3、编译器运行test.cpp文件,此时通过%u成功打印出了unsigned long类型的数据。

c语言中printf格式解释
3. 标志字符:一些格式指示符还可以附加标志字符,如“-”表示左对齐,“+”表示显示正号,“#”在某些情况下有特殊用途等。这些标志字符可以改变输出的格式和外观。四、示例说明 1. printf; \/\/ 输出整数123。2. printf; \/\/ 输出字符串"Hello, World!"。3. ...

在C语言中“%c%c\\n”和“%d%d\\n“分别说明什么。。。??
这两个格式字符都是紧挨着输出的,如果想要它们之间留出一定的间隔,可以通过增加输出字段的宽度或者在两个格式字符之间插入空格、逗号等字符来实现。例如,使用 "%5d" 可以使整型数据按照 5 个字符的宽度输出,而在 "%d%d" 之间插入空格,则可以实现两个整型数据之间的空格间隔。在 C 语言中,常用的...

c语言中%s是什么意思?
在C语言中,%s表示字符串格式说明符。接下来 一、格式说明符的概念 在C语言中,当我们使用printf或scanf等函数进行输入输出时,常常会遇到格式说明符。格式说明符用于指定数据输入输出的格式。例如,%d表示十进制整数,%f表示浮点数等。二、%s的具体含义 s是其中的一个格式说明符,用于表示字符串。当我们...

C语言中输出指数是怎么输出的?
C语言中输出指数格式:使用格式控制符“%e”以指数形式输出实数。printf的格式控制的完整格式:- 0 m.n l或h 格式字符 其中格式控制说明如下:下面对组成格式说明的各项加以说明:①%:表示格式说明的起始符号,不可缺少。②-:有-表示左对齐输出,如省略表示右对齐输出。③0:有0表示指定空位填...

c语言中%*d是什么意思
c语言中%*d表示忽略第一个整数,而%*d中的*,是一个标志符号,用来表示跳过它相应的数据,表示输出的数据区和它对应的数据表示输出的空格个数,从而使下一个输入的内容复制给紧接着的变量。c语言格式介绍:%d是输出整型数据,%和格式字符组合在一起的作用是将输出的数据转换为指定的格式输出。%d是带...

c语言中的“%d,%s,%c,%d,%f,%s”是什么意思
这一类符号是“格式说明”,用于格式的输入与格式的输出,就是当printf和scanf函数中在输入输出时,对不同类型的数据(如int,float,char等)要使用不同的格式来进行说明。d,用来输出十进制整数。f,用来输出实数(包括单,双精度),以小数形式输出,默认情况下保留小数点6位。c,用来输出一个字符。s,...

C语言怎么用printf输出字符串。
C语言怎么用printf输出字符串printf函数的一般格式printf(格式控制字符串,输出表列);以图1所示为例。图1.函数参数包括两部分:【1】格式控制字符串,是用双引号括起来的字符串,也称为转换控制字符串,它指定输出数据项的类型和格式。它包括两种信息:●格式说明项:由%和格式字符组成,如%d,%f...

C 语言 标准输入输出
在输出时,若希望输出特定进制的前缀,可在%和符号之间加上#。浮点型和指针类型输出时,可以使用%[ ]格式,读入一个字符集合,如大写字母等。当使用%[^\\n]读取字符串时,需注意读取换行符,避免下一次读取时读入空字符串。在使用C语言时,遇到输出问题时,常见问题大多与格式说明符的正确使用相关。ty...