格式化输出函数是什么?

zZ 2024-05-26 18:17:24
最佳回答
为了方便理解一个例 对于如下的格式化匹配字串: "|%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 '.   注: 如果你用这个参数来格式化输出一个指针类型的参数时,有可能会得到一个'(**)'的输出值。不过有时候用于指针为空的缘故程序运行时会产生“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。 '%%'是输出“%”的字符。 hope** 回复于: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 toefl**", fp);/*向所建文件写入一串字符*/ fputc(':', fp); /*向所建文件写冒号:*/ fprintf(fp, "%d", i); /*向所建文件写一整型数*/ fprintf(fp, "%s", s); /*向所建文件写一字符串*/ fclose(fp); /*关闭文件*/ } [/code:1:7cfd895035]   用cat命令显示test.dat的内容如下所示:屏幕显示 your score of toefl **: 617 that's good news 4.3 sprintf() 函数   sprintf(string, fmt, ...)传回的是string的类型的数组,并以空字符结尾。不过,该函数有可能超过为字符分配的长度。比较危险。下面是一个sprintf()的事例。 [code:1:7cfd895035] int //根据传进来的m**sion数据结构,建立socket链接,取得文件的大小。 get_size_of_url(struct m**sion* 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)) == **) 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] 20210311
汇率兑换计算器

类似问答
  • excel2016中函数公式查找表格重复数据的方法
    • 2024-05-26 04:42:48
    • 提问者: 未知
    1我们首先打开excel表格,生成一些随机数据进行操作。2然后,我们选中需要显示重复数据的单元格。3此时输入函数:“=if(countif(b$2:b2,b2)>1,”重复数据”,””)”函数的意义是,如果有重复数据录入,将会提示汉字:重复数据4完成输入后,我们按下enter键,然后回车。在左下角拖动至全表格。5这时,我们重复输入的数据会自动显示出来。end
  • 效用函数的公式是什么
    • 2024-05-26 13:57:13
    • 提问者: 未知
    5、—第i种运输方式的费用,有时也称为效用函数,u=ao+alx一+灸xc....6、为了对控制做出评价,需要一套函数作为评价指标:j(t)=∑k=0kγu(t+k)=u(t)+jγ(t+1)(2)其中u(t)=u[r(t),a...
  • 什么是数据格式bs8
    • 2024-05-26 09:03:16
    • 提问者: 未知
    bs8表示自定义格式,长度为1字节,每位表示的含义字节定义。如状态量接入标志位的数据格式为bs8,根据376.1-2009规定其d0~d7位分别对应第1~8路状态量输入,相应位置1表示接入,置0表示未接入。
  • excel 函数irr irr函数内部计算公式是什么?
    • 2024-05-26 01:45:06
    • 提问者: 未知
    excel函数教程2113:irr,irr-内部收益率的函数。操作方法如下5261: 1、首先在电脑中打4102开表格,找到1653进行计算的内容。2、然后点击b7-点击函数图标fx。3、插入函数参数框-选择函数类别(常用函数或财务函数)。4、选择irr,点击确定。5、跳出函数参数框,点击values图标,然后按shift+...
  • 在matlab中如何输出一个函数的图像
    • 2024-05-26 17:36:08
    • 提问者: 未知
    如果要画y=x^3+x^2+x+5在[-20,20]上的图像,可利用以下方法,绘画区间可以自己定义:方法一:利用plot函数来绘画图像x=0:0.1:20;规定绘画区间(从-20画到20,中间以0,1为间隔)y=x.^3+x.^2+x+5...
  • 怎么用excel的条件格式函数对有数据的行进行隔行变色,奇数和偶数时怎么输入公式?用到len,mod的
    • 2024-05-26 00:26:47
    • 提问者: 未知
    一、请输入条件公式:=if(数据/2=int((数据/2)),就能判定奇偶数:即:数据为偶数时时条件显示为t,当数据为奇数时条件显示为f。 二、隔行变色:请选择整行或表格整行单元格,选择通过条件格式设置,在管理规则中输入公式:=if(row()/2=int((row()/2)),就表明偶数行符合条件,会按你要求变换成设置的颜色了。同时复制该行或表格行,再选择整个表格行或表格,右键点击用"...
  • 股票预测用的什么函数,公式是什么?
    • 2024-05-26 13:32:45
    • 提问者: 未知
    你说的是测试指标公式的未来函数啊,百度搜索未来函数检测工具,一大堆。有未来函数的公式,慎用啊。
  • 指数函数和对数函数的运算公式
    • 2024-05-26 05:22:37
    • 提问者: 未知
    1对数的概念 如果a(a>0,且a≠1)的b次幂等于n,即ab=n,那么数b叫做以a为底n的对数,记作:logan=b,其中a叫做对数的底数,n叫做真数. 由定义知: ①负数和零没有对数;②a>0且a≠1,n>0;③loga1=0,logaa=1,alogan=n,logaab=b. 特别地,以10为底的对数叫常用对数,记作log10n,简记为lgn;以无理数e(e=2.718 ...
  • 确认函如何回复,格式是什么?
    • 2024-05-26 18:54:22
    • 提问者: 未知
    私募基金合格投资者确认函 债权债务转移确认函该怎么写?展开全文 看完仍有疑问?想要更详细的答案?获取专业解答 更快速 更准确 更全面 更多#经营管理 相关 61559次浏览 ...
  • 数据输入/输出常用的三种方式?
    • 2024-05-26 23:36:41
    • 提问者: 未知
    计算机与外设之间进行数据传送有三种基本控制方式:查询方式、中断方式和dma方式 1.查询方式 查询方式是通过执行输入/输出查询程序来完成数据传送的。 工作原理是:当cpu启动外设工作后,不断地读取外设的状态信息进行测试,查询外设是否准备就绪,如外设准备好,则可以进行数据传送;否则,cpu继续读取外设的状态信息进行查询等待,直到外设准备好。 采用程序查询方式进行数据传送时,实际上在外设准备就...
汇率兑换计算器

热门推荐
热门问答
最新问答
推荐问答
新手帮助
常见问题
房贷计算器-九子财经 | 备案号: 桂ICP备19010581号-1 商务联系 企鹅:2790-680461

特别声明:本网为公益网站,人人都可发布,所有内容为会员自行上传发布",本站不承担任何法律责任,如内容有该作者著作权或违规内容,请联系我们清空删除。