重新温习fscanf和fprintf的格式化串

一、完整格式

%   - 0   m.n  l或h   格式字符

① % :表示格式说明的起始符号,不可缺少。 
② - :有-表示左对齐输出,如省略表示右对齐输出。 
③ 0 :有0表示指定空位填0,如省略表示指定空位不填。 
④ m.n :m指域宽,若数据的位数小于m,则左端补空格,若大于m,则按实际位数输出。 
       n指精度,用于说明输出的实型数的小数位数。未指定n时,隐含的精度为n=6位。 
⑤ l或h :l对整型指long型,对实型指double型。h用于将整型的格式字符修正为short型。 

二、格式字符

① 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格式:输出指针地址 

三、实例

如果想输出字符"%",则应该在“格式控制”字符串中用连续两个%表示,如: 
printf("%f%%", 1.0/3); 
输出0.333333%。 


对于m.n的格式还可以用如下方法表示 
char ch[20]; 
printf("%*.*s\n",m,n,ch); 
前边的*定义的是总的宽度,后边的定义的是输出的个数。分别对应外面的参数m和n 。 
这种方法的好处是可以在语句之外对参数m和n赋值,从而控制输出格式。 

如何用printf 实现可变的域宽度? 就是说,我想在运行时确定宽度而不是使用 %8d 
使用 printf("%*d", width, x) 
格式说明符中星号表示,参数列表中的一个int值用来表示域的宽度。
########### printf 是 右(先)入栈 ###########
#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
 
int main()
{
    uint64_t a = 0x0000000100000002;
    int rc = -5;
    printf("%llu leon %d\n", a, rc);
    //out: 4294967298 leon -5
 
    printf("%d leon %d\n", a, rc);
    //out: 2 leon 1
 
    printf("%d again %d %d\n", a,rc);
    //out: 2 again 1 -5
 
    uint32_t b ;
    memcpy(&b, &a, sizeof(uint32_t));
 
    printf("%d kjfsfljs\n", b);
    //out: 2 kjfsfljs (说明是小端)
 
    return 0;
}
补充:# 
printf("c=%#x\n",c);什么意思?
这里的"c=%#x\n"意思是:是一个格式控制符,其中c=是普通字符,%#x是格式说明,\n是转义字符;其中的%#表示的输出提示方式,如果是8进制,在前面加0,如果是十进制,不加任何字符,如果是十六进制,会加上0x
举例说明:当c='\x41';//这里应该是单引号
当执行:printf("c=%#o\n",c);输出的是:0101(把16进制41转化为2进制)
printf("c=%#d\n",c);输出的是:65(把16进制41转化为10进制)
printf("c=%#x\n",c);输出的是:0x41

猜你喜欢

转载自blog.csdn.net/u010258235/article/details/124353010