1. 首页 > 科技

C语言中的格式化输出函数和格式化输入函数分别是什么? c语言中格式化输入函数为

C语言中的格式化输出函数和格式化输入函数分别是什么?c语言中格式化输入函数为

格式化输出函数是什么?

为了方便理解给出一个例子: 对于如下的格式化匹配字串:

"|%5d|%-5d|%+5d|%+-5d|% 5d|%05d|%5.0d|%5.2d|%d|" 将产生类似如下的输出: | 0|0 | +0|+0 | 0|00000| | 00|0|

| 1|1 | +1|+1 | 1|00001| 1| 01|1|

| -1|-1 | -1|-1 | -1|-0001| -1| -01|-1|

|100000|100000|+100000| 100000|100000|100000|100000|100000| 对于如下的格式化匹配字串:

"|%5u|%5o|%5x|%5X|%#5o|%#5x|%#5X|%#10.8x|" 将产生类似如下的输出: | 0| 0| 0| 0| 0| 0x0| 0X0|0x00000000|

| 1| 1| 1| 1| 01| 0x1| 0X1|0x00000001|

|100000|303240|186a0|186A0|0303240|0x186a0|0X186A0|0x000186a0| 3.2 浮点数的转换部分   浮点数转换部分主要是'%f', '%e', '%E', '%g', 和 '%G' '这几个参数命令的,由于参数的不同,可以输出不同格式的结果。如上表所列: '%f'是输出一个比较固定形式的浮点数……其中,针对这几种不同输出选择还有如下几个参数项: '-’ 表示是左对齐,一般都是右对齐的。

'+’ 是指以'+’符号表示正数

' ' 如果输出不是以'+’'-’开头的,那么用空格做开头

'#' 是对'%g'和'%G’参数而言的,将在输出的结果强制加上'0’为开头。

''' 将输出的数字以LC_NUMERIC的分类法用’,’隔开。

'0' 将空格的地方用“0'填入。

  如果没有特别指定,传入的被格式化的参数默认是double类型的,可以用'L’表示是一个long double类型的。   如下例子可以看出浮点数格式化的字串:   如下的格式字串: "|%12.4f|%12.4e|%12.4g|"   可能产生如下的输出: | 0.0000| 0.0000e+00| 0|

| 1.0000| 1.0000e+00| 1|

| -1.0000| -1.0000e+00| -1|

| 100.0000| 1.0000e+02| 100|

| 1000.0000| 1.0000e+03| 1000|

| 10000.0000| 1.0000e+04| 1e+04|

| 12345.0000| 1.2345e+04| 1.234e+04|

| 100000.0000| 1.0000e+05| 1e+05|

| 123456.0000| 1.2346e+05| 1.234e+05| 3.3 其他格式的转换部分   这部分的函数比较简单一些,具体如下: '%c’是指输出一个单个的字符串,默认的输出的被格式化的参数是unsigned char类型的,可以用'-’表示左对齐的。没有的别的参数,比如:

printf ("%c%c%c%c%c", 'h', 'e', 'l', 'l', 'o'); 显示结果为: 'hello' '%s’是输出一个字串,. 默认的输出的被格式化的参数是char * (or const char *). 类型的,可以用'-’表示左对齐的。没有的别的参数,比如:

printf ("%3s%-6s", "no", "where"); 显示结果: ' nowhere '.   注: 如果你用这个参数来格式化输出一个指针类型的参数时,有可能会得到一个'(null)'的输出值。不过有时候用于指针为空的缘故程序运行时会产生“Segmentation fault”的错误,下面一个例子就会产生这样的错误: [code:1:2b36d1dc8e]

#include

main()

{

char a;

a = inet_addr("192.168.1.1");

if(a!=-1){

printf("ip:%s",a);/* 这里的%s可能会产生错误,应改用用%p比较好一些*/

}

} [/code:1:2b36d1dc8e] '%m’是输出error信息的。如下例子:

fprintf (stderr, "can't open '%s': %m", filename); 等于如下的输出命令: fprintf (stderr, "can't open '%s': %s", filename, strerror (errno)); “%p”是输出指针类型参数的,显然被格式化的输入蚕室必须是指针,可以用“-”来表示左对齐的。

“%n”是比较特殊的参数,它不对格式化输出影响,而是得到输出结果的字符长度,可以用类型指定参数'h' 和 'l'来分别指定输出的参数分别是short int *和 long int *类型的。如下面的例子:

int nchar;

printf ("%d %s%n", 3, "bears", &nchar); 输出结果: 3 bears 同时将7的值赋给变量nchar。 '%%'是输出“%”的字符。

HopeCao 回复于:2003-02-28 13:19:11

<三> 4.函数具体介绍 4.1printf()函数   printf()函数是格式化输出函数系列中比较有具有普遍特点的, 一般用于向标准输出设备按规定格式输出信息。在编写程序时经常会用到此函数。printf()函数的调用格式为:   printf("<格式化字符串>", <参量表>;

[code:1:7cfd895035]

#include

#include

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;

}

[/code:1:7cfd895035]   上面结果中的地址值在不同计算机上可能不同。   例子中第一条语句#include的含义是调用另一个文件stdio.h, 这是一个头文件, 其中包括全部标准输入输出库函数的数据类型定义和函数说明。对每个库函数便用的变量及函数类型都已作了定义与说明, 放在相应头文件"*.h"中, 用户用到这些函数时必须要用#include<*.h>或#include"*.h" 语句调用相应的头文件, 以供若没有用此语句说明, 则连接时将会出现错误。 4.2 fprintf()函数   fprintf( 函数中格式化的规定与printf( 函数相同, 所不同的只是fprintf()函数是向文件中写入。而printf()是向屏幕输出。   下面介绍一个例子, 运行后产后一个test.dat的文件。 [code:1:7cfd895035]

#include

main()

{

char *s="That's good news"}; /*定义字符串指针并初始化*/

int i=617; /*定义整型变量并初始化*/

FILE *fp; /*定义文件指针*/

fp=fopne("test.dat", "w"); /*建立一个文字文件只写*/

fputs("Your score of TOEFLis", fp);/*向所建文件写入一串字符*/

fputc(':', fp); /*向所建文件写冒号:*/

fprintf(fp, "%d", i); /*向所建文件写一整型数*/

fprintf(fp, "%s", s); /*向所建文件写一字符串*/

fclose(fp); /*关闭文件*/

}

[/code:1:7cfd895035]

  用CAT命令显示TEST.DAT的内容如下所示:屏幕显示 Your score of TOEFL is: 617

That's good news 4.3 sprintf() 函数   sprintf(string, fmt, ...)传回的是string的类型的数组,并以空字符结尾。不过,该函数有可能超过为字符分配的长度。比较危险。下面是一个sprintf()的事例。

[code:1:7cfd895035]

int

//根据传进来的Mission数据结构,建立socket链接,取得文件的大小。

get_size_of_url(struct Mission* pms)

{

int s;

struct sockaddr_in sin;

struct hostent* phe;

char cmd[256];

char msg_hdr[1000];

char* p;

//准备http中GET 方法的请求。

sprintf(cmd,"GET %s HTTP/1.0", pms->url);

//创建socket

if((s=socket(PF_INET,SOCK_STREAM,0))<0)

return -1;

//取得远程主机的IP地址,失败函数返回-1

if((phe = gethostbyname(pms->host)) == NULL)

return -1;

memset(&sin,0,sizeof(sin));

memcpy(&sin.sin_addr,phe->h_addr,sizeof(struct in_addr));

sin.sin_family=AF_INET;

sin.sin_port=htons(pms->port);

//跟远程机器建立连接,失败函数返回-1

if(connect(s,(struct sockaddr*)&sin,sizeof(sin))==-1)

return -1;

//发送GET请求

if(write(s,cmd,strlen(cmd))<0)

return 0;

//从链接描述符(连接管道)中读取传送过来的数据

if(read(s, msg_hdr, 300)<0)

return 0;

close(s);

printf("%s",msg_hdr);

//读到该文件的大小

if((p=strstr(msg_hdr,"Content-Length"))||(p=strstr(msg_hdr,"Content-length:")))

p+=16;

else

return 0;

//返回大小

return atoi(p);

}

[/code:1:7cfd895035]

c语言格式化输入和输出函数

scanf() 输入,比如你定义了一个i变量,想通过键盘输入来给i一个值,代码如下:

int i;

scanf("%d",&i);      //%d,数据类型,&i,&取地址,不理解也没关系,记住要这么用就行了这样你就可以通过键盘来键入i的值了,但是这样并不够人性化,因为没有任何的提示,于是我们用printf()来做一个提示,代码如下:

int i;

printf("请输入i的值: "); //在窗口上显示引号内的内容

scanf("%d",&i);

C语言中,格式化输入函数为( ),格式化输出函数为( )。

输入

scanf("%d",&x); //一定要记住&符号,即使没有这个符号,VC++平台是检测不出来的,很多时

//候程序出错可能就是这个地方。

输出

printf("%d",x); //这个不用多说噻,至于字符和字符串的操作再说。

c语言中的格式化输出什么意思?

格式化输出是指通过printf(),sprintf(),snprintf(),fprintf()等函数向指定的地方(比如屏幕)输出指定格式的内容

例如

%d 输出十进制数

%s 输出字符串

%c 输出字符

%x 输出十六进制数

等等

//...

int x=16;

printf("%d %x\n",x,x);

//.....

输出的就是

16 10