格式化输入/输出(c语言超详细系列)(一)

这篇具有很好参考价值的文章主要介绍了格式化输入/输出(c语言超详细系列)(一)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言;

Hello,大家好,我是心跳sy,今天我们主要讨论一下格式化输入/输出(一),包括printf,scanf的基本使用方法及注意事项、转换说明的简单理解以及转义序列的讲解,后续将持续带来对转换说明的深入研究以及输入缓冲的概念与文件相联系的知识,以及包括字符的输入输出、行的输入输出、块的输入与输出。今天我们讨论的知识将是c语言入门时所广泛涉猎的内容,以及汇总我们经常会踩的坑,我们一起来看看吧~~

1、printf 函数

 基本格式:printf(格式串,表达式1,表达式2,...);printf函数被用来显示格式串的内容,并在该串的指定位置插入可能的值。在调用printf时必须提供格式串,格式串后的参数是显示时插入该串的值(可以是常量、变量、以及复杂的表达式)。

格式串:包含普通字符以及转换说明,其中转换说明以%开头 。转换说明是用来表示打印过程中待填充的值的占位符,跟在%后面的信息则指定了把数值从计算及内部形式(二进制)转换成想要打印的形式。

例如:转换说明%d指定printf函数把int型值从二进制形式转换成十进制形式。

*需要注意以下几点:

1、格式串中的普通字符要完全“复制”显示出来, 而转换说明则要用带显示的值来“替换”。例如:

    int i, j;
	float x, y;
	i = 1;
	j = 2;
	x = 2.55f;
	y = 20.0f;
	printf("i=%d,j=%d\nx=%f,y=%f",i,j,x,y);

输出结果:可以看出,格式串中普通字符“i=、j=、x=、y=”和“逗号”被“复制”给输出行,而变量i,j,x,y的值则则依次替换了4个转换说明。

 文章来源地址https://www.toymoban.com/news/detail-639073.html

格式化输入/输出(c语言超详细系列)(一),c语言,开发语言

2、要注意格式串中转换说明是否和输出项的数量匹配。

·当转换说明数量多于要显示的值的数量时:

    int i = 1;
	int j = 2;
	printf("%d %d\n", i);

输出结果: 可以看出printf函数将正确显示i的值,接着显示一个无意义的值。

 格式化输入/输出(c语言超详细系列)(一),c语言,开发语言

·当转换说明数量少于要显示的值的数量时:

    int i = 1;
	int j = 2;
	printf("%d\n", i, j);

输出结果: 可以看出只输出i的值,不显示j的值。

格式化输入/输出(c语言超详细系列)(一),c语言,开发语言 

·也要注意使用正确的转换说明与显示项的匹配:

    int i = 1;
	float j = 2.5f;
	printf("%d %f", j, i);

输出结果:可以看出,将int型变量i与float型变量j的顺序放错,程序将产生无意义的输出。 

格式化输入/输出(c语言超详细系列)(一),c语言,开发语言 

2、转换说明

* 转换说明给程序员们提供了大量的输出格式的控制方法,转换说明有时包含格式化信息,例如:用%.1f来显示小数点后带一位数字的float型值。

* 一般的,转换说明可用%m.pX格式或-%m.pX格式这里的mp都是整形常量,而X是字母。mp都是用户根据需求自定义的,如果省略p,则mp之间的小数点也要去掉。

·例如:在转换说明10.2f中,m是10,p是2,而X是f。如果转换说明为%10f时,m是10,p连同小数点一起省略了,而如果转换说明为%.2f时,p是2,m省去了。

转换说明%m.pX中,m指定了要显示的最少字符数量,称为最小栏宽。(可理解为输出显示字符总数m)

*如果要显示的数值所需字符数少于m,那么值在字段内是右对齐的(在值前面加空格凑数),例如:%4d将以 123的形式显示数123(123前加一个空格)。

*如果要显示的数值数量多于m,那么栏宽将会自动扩展;例如:%4d将以12345的形式显示数12345,而不会丢失数字。

*在m前加上负号会导致显示数值左对齐;例如:%-4d将以123 的形式显示123(123的后面有一个空格)

转换说明%m.pX中,p称为精度。(在浮点数中可表示小数点后p位)它依赖于转换指定符X的选择,X表明在显示数值前需要对其进行哪种转换。下面介绍几个常用的转换指定符(全面表格以后会详细介绍)

*d——表示十进制形式的整数。p指明了待显示数值的最少个数(若缺可在数前加额外的零)

*e——表示指数(科学计数法)形式的浮点数。p指明了小数点后应该出现的数字个数(默认值为6)。如果p为0,则不显示小数点。

*f——表示浮点数,没有指数,p的含义与说明符e一样。

*g——表示指数形式或者定点十进制形式的浮点数。形式的选择根据数的大小决定,p意味着可以显示的有效数字的最大数量(不是小数点后的数字),与f不同,g的转换将不显示尾随的零(如果g要显示的数值没有小数点后的数字,g就不会显示小数点)。在显示大小适中的数时,g采用定点十进制;在显示非常大或非常小的数时,g则会转换成指数形式。

    int i;
	float x;
	i = 40;
	x = 200.20f;
	printf("|%d|%5d|%-5d|%5.3d|\n", i, i, i, i);
	printf("|%10.3f|%10.3e|%-10g|\n", x, x, x);

输出结果: 

格式化输入/输出(c语言超详细系列)(一),c语言,开发语言 

 解析:

·%d——以十进制形式显示变量i,占用最少空间。

·%5d——以十进制形式显示变量i,且至少占用5个字符的空间。因为i只占2个字符,所以前面添加了3个空格。

·%-5d——以十进制形式显示变量i,且至少占用5个字符的空间。因为i的值不需要满5个字符,所以在后续位置添加空格(数左对齐)。

·%5.3d——以十进制形式显示变量i,至少占用5个字符的空间,并至少有3位数字,因为变量i只有2个字符长度,所以需要添加一个额外的零来保证有三位数字(现在只有3个字符长度,为保证占5个字符,还需要添加2个空格,注意是右对齐的)

·%10.3f——以定点十进制形式显示变量x,且总共10个字符,其中小数点后保留3位小数,因为变量x只需要7个字符(算小数点),所以在前面补位3个空格。

·%10.3e——以指数形式显示变量x,且总共10个字符,小数点后保留3位数字。因变量x有9个字符,所以前面补位一个空格。

`%-10g——既可以定点十进制形式显示变量x,也可以以指数形式显示变量x,且总共10个字符,因数字较小,所以选择定点十进制的形式,左对齐,后面跟4个空格。

3、转义序列

 格式串中常用到的\n就被称为转义序列,转义序列常包含一些特殊字符而不会引起编译器报错,这些字符包括非打印的控制字符和一些特殊含义字符。先介绍几个常用的转义符:

*警报响铃符:\a            //会产生一声鸣响

*回退符:\b                   //会使光标从当前位置退回一个位置

*换行符:\n                   //会使光标跳到下一行的起始位置

*水平制表符:\t             //会把光标移动到下一个制表符位置(一般来说,水平制表符之间距                                        //离是8个字符长度,意为补全当前长度到8,但也依据本身所使用的                                        //操作系统,一般是8的整数倍)

*表示字符“:\“               //显示输出字符“

 格式化输入/输出(c语言超详细系列)(一),c语言,开发语言

·下图展示了水平制表符与换行符作用: 

printf("Item\tUnit\tPutchase\n\tPrice\tDate\n");

 输出结果: 可以看到水平制表符占8个字符长度(包含输出字符本身,不够8的补4个空格)

 格式化输入/输出(c语言超详细系列)(一),c语言,开发语言

·如果要显示“ ”: 

printf("\"Hello!\"");

 输出结果: 

 格式化输入/输出(c语言超详细系列)(一),c语言,开发语言

 4、scanf 函数

*同printf一样,scanf也根据特定的格式进行读取输入。scanf的格式串也可以包含普通字符和转换说明两部分

*在许多情况下,scanf函数的格式串仅包含转换说明,例如:scanf(“%d %d”,&i,&j); 假设用户输入1 -2

 scanf函数的作用是读入用户输入信息,然后分别把1 -2赋值给变量i,j。

*需要注意的是:第一:使用scanf函数时,必须检查转换说明的数量是否与输入变量的数量匹配,并检查每个转换是否与变量相对应;第二:&通常放在每个变量前,一定不要忘记,除特殊情况(当本身就表示地址信息时,因为&的意思本就是取地址)。

scanf意义再解读 

 scanf函数本质上是一种“模式匹配”函数,试图把输入的字符与转换说明匹配。当调用scanf函数时,scanf从最左端开始处理字符串中的信息,对于每一个转换说明,scanf函数都会定位匹配的项,并在必要时跳过空格,然后scanf继续读取输入项,直到遇到不可能匹配的字符停止读取,把剩余字符交给下一个scanf读取。

我们来看一个很容易混淆的实例: 

    int i, j;
	float x, y;
	scanf("%d%d%f%f", &i, &j, &x, &y);
	printf("i=%d,j=%d,x=%f,y=%f", i, j, x, y);

这里我们输入1-20.3-4.0e3\n

输出结果: 

 格式化输入/输出(c语言超详细系列)(一),c语言,开发语言

解释:

*转换说明%d:第一个非空输入的字符是1,整数可以从1开始,所以scanf继续向下读取,遇到-,scanf判断出负号不与整数%d转换说明匹配,所以将1存入i中,将-放回原处。

*转换说明%d:随后scanf读取-、2、0 和 . ,scanf成功读取-20整数存入j,遇到小数点,与转换说明不匹配,把字符 . 放回原处。

*转换说明%f:scanf读取 . 、3、- 字符,因为浮点数后不能有负号,所以scanf把0.3存入x中。-放回原处。

*转换说明%f:最后scanf读取-、4、. 、0、e、3和换行符,因为浮点数不包括换行符,所以scanf将-4.0*10的3次方存入y,把换行符放回原处(缓冲区,我们下次详细介绍),留给下一次scanf调用。

*注:在使用scanf时一定要注意格式匹配,在读取字符串时,只要遇到一个空格,scanf() 就会停止读取,所以 "this is test" 对 scanf() 来说是三个字符串;又如:在scanf(“%d,%d",&i,&j);中,scanf函数首先寻找合适输入整数,存入i中,然后scanf试图把逗号与下一个输入字符匹配,如果下一个字符是空格而不是逗号,那么scanf函数将终止操作,不再读取j的值。

后期将继续带来有关输入输出的再解读,感谢各位大佬友友们阅读!!!如有问题欢迎各位大佬在评论区指正支持!!!

格式化输入/输出(c语言超详细系列)(一),c语言,开发语言

 

 

 

 

 

到了这里,关于格式化输入/输出(c语言超详细系列)(一)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • AWK语言第二版 1.3 格式化输出

    前一节的 print 语句用于简单和快速的输出。如果对输出格式有更高要求,就要使用 printf 语句。本书后面的例子中,可以看到  printf 语句能生成几乎任意格式的输出,不过本节只会展示它的一小部分能力。细节可以参考附录 A.4.3。 对齐域 printf 语句的格式是 其中的 format 是一

    2024年02月10日
    浏览(23)
  • C语言格式化输出函数printf详解——C语言基础知识

    (由于篇幅较长,内容较全,建议收藏) printf函数的一般格式为: printf(格式控制字符串,输出值参数表); 如: 其中, f=%f,c=%fn 是 格式控制字符串 , f,c 是 输出值参数表 。 (1)格式控制字符串是用双引号括起来的字符串,包括三类信息: 格式字符。格式字符由“%”

    2023年04月08日
    浏览(31)
  • Python遇上OpenAI系列教程【一】:如何格式化输入到chatgpt模型

    点击加入-【OpenAI-API开发】技术交流群 Chatgpt由Openai最先进的型号 gpt-3.5-Turbo 和 gpt-4 提供支持。我们可以使用OpenAI API使用 GPT-3.5-Turbo 或 GPT-4 构建自己的应用程序。 聊天模型将一系列消息作为输入,然后返回AI写的消息作为输出。 本指南用一些示例API调用说明了聊天格式。 聊

    2024年02月13日
    浏览(29)
  • C语言中的格式化输出符号:%d %c %p %x等

    C语言中的格式化输出符号有很多,以下是一些常见的: %d 或 %i:用于输出十进制整数。 %u:用于输出无符号十进制整数。 %f:用于输出浮点数。 %s:用于输出字符串。 %c:用于输出字符。 %p:用于输出指针。 %x 或 %X:用于输出十六进制数,%x表示输出小写字母,%X表示输出大

    2024年01月18日
    浏览(32)
  • python格式化输出

    偶然看到一种格式化输出这么写的 可以看到 %(key)s 包围的值可以通过字典对应的值指定 另外的格式化输出还有 \\\"\\\".format() , \\\"\\\" % , f\\\"{}\\\"

    2024年02月05日
    浏览(25)
  • Python基础—格式化输出

    一、旧式字符串格式化方法 %s、%d、%f等被称为占位符,%s对应字符串、%d对应整型、%f对应浮点型 %f -- 默认保留6位小数 %.Nf -- N为整数 %f -- 四舍五入 二、format方法 在字符串中写{},字符串外调用format方法,在format方法中传入值,按照一一对应的关系被写入对应的{} 作用为说明

    2024年02月08日
    浏览(34)
  • C++常用格式化输出转换

     在C语言中可以用printf以一定的格式打印字符,C++当然也可以。 输入输出及命名空间还不太了解的小伙伴可以看一看C++入门讲解第一篇。  在C++中,可以用流操作符(stream manipulators)控制数据的输出格式,这些流操作符定义在2个头文件( iomanip 和 ios )中,可以用输出运算

    2024年02月04日
    浏览(33)
  • 【Python入门篇】——Python基础语法(字符串格式化,表达式格式化和数据输入)

    作者简介: 辭七七,目前大一,正在学习C/C++,Java,Python等 作者主页: 七七的个人主页 文章收录专栏: Python入门,本专栏主要内容为Python的基础语法,Python中的选择循环语句,Python函数,Python的数据容器等。 欢迎大家点赞 👍 收藏 ⭐ 加关注哦!💖💖 目前通过%符号占位

    2024年02月05日
    浏览(40)
  • 关于使用JS获取当前时间并格式化输出

    (1)逐个提取并拼接字符串 (2)一步到位提取年月日时分秒(重点) 首先,提取数据到数据 然后,拼接数据格式化输出 (附上,过程剖析)

    2024年02月03日
    浏览(44)
  • Python 格式化输出:精确控制你的数据表示

          目录 旧式的 % 运算符(不推荐) str.format() 方法 位置和参数: 格式化数字: f-string 表达式和函数调用: 格式化数字: 格式规范的微调 (核心) 对齐字符串 填充字符 数字的零填充 数字的千位分隔符 格式化十六进制、八进制和二进制         在编程语

    2024年01月17日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包