C语言中输入输出格式控制
1、C语言中,非零值为真,真用1表示;零值为假,假用0表示。
2、转义字符参考:
\a |
蜂鸣,响铃 |
\b |
回退:向后退一格 |
\f |
换页 |
\n |
换行 |
\r |
回车,光标到本行行首 |
\t |
水平制表 |
\v |
垂直制表 |
\\ |
反斜杠 |
\' |
单引号 |
\" |
双引号 |
\? |
问号 |
\ddd |
三位八进制 |
\0 |
空字符(NULL),什么都不做 |
\xhh |
二位十六进制 |
说明:
1)\v垂直制表和\f换页符对屏幕没有任何影响,但会影响打印机执行响应操作。
2),\n其实应该叫回车换行。换行只是换一行,不改变光标的横坐标;回车只是回到行首,不改变光标的纵坐标。
注:
文本文件的行结束符,传统上(MS)PC用 CRLF,苹果Mac用CR,unix 用 LF。
CR -- 回车符,c语言'\r'
LF -- 换行符, c语言'\n'
不同计算机上c语言统一规定为:文本文件的行结束符一律变成一个符号LF,也就是换行符'\n'。“回车和换行符转换成一个换行符”,对PC(MS OS)而言,文本文件行结束符CRLF读入后,丢掉CR,留LF。例如fgets() 读入一行,行尾只有LF,没有CR。
3)\t光标向前移动四格或八格,可以在编译器里设置
4)\'在字符里(即单引号里)使用。在字符串里(即双引号里)不需要,只要用 '即可。
3、格式化输入输出
1)格式化输入
printf("格式串" [,表达式1,表达式2,···]);
其中,格式串的字符有两类:
① 以%开头引导的格式符,用于控制表达式的输出格式(有多少个表达式,就有多少个格式符);
② 非格式符:原样显示在屏幕上。
(1)字符串常量的输出
无表达式,格式串中无格式符,如:
printf("We are students.\n");
(2)格式符的语法
syntax: %[flag][width][.precision][h|l|L]type
a)[h|l|L]type
type字段采用一个英文字母来表达数据类型与格式:
d |
按十进制有符号整数形式输出 |
i |
按十进制有符号整数形式输出(同d格式) |
u |
按十进制无符号数形式输出 |
o |
按八进制无符号数形式输出 |
x |
按十六进制无符号数形式输出,输出时使用小写字母 (a, b, c, d, e, f) |
X |
按十六进制无符号数形式输出,输出时使用大写字母(A, B, C, D, E, F) |
f |
按十进制小数形式输出浮点数,输出格式为:[-]ddd.dddddd(默认输出6位小数) |
e |
按十进制指数形式输出浮点数,输出格式为:[-]d.dddde[+/-]ddd,(e后面是指数) |
E |
按十进制指数形式输出浮点数,输出格式为:[-]d.ddddE[+/-]ddd,(E后面是指数)。 用e和E格式输出浮点数时,输出的是科学记数法形式,即小数点前面的整数部分固定为1位整数 |
g |
按十进制形式输出浮点数,自动选择f或e格式中,输出长度小的格式输出;g格式不输出无用的0。 |
G |
按十进制形式输出浮点数,自动选择f或E格式中,输出长度小的格式输出;G格式不输出无用的0。 |
c |
输出单个字符 |
s |
输出字符串 |
p |
输出void指针,输出格式是:WIN32编程模式,只有XXXXXXXX一种格式 |
% |
输出字符%(%用于引导格式控制符,在格式串中输出%号时,必须采用格式%%) |
前缀修饰符:
L: 输出long double类型表达式必加
l: 输出长整型表达式必加
h: 输出短整型表达式必加
b)[width]
width字段用来指定输出的数据项占用的字符列数,也称为输出域宽。缺省该字段,输出宽度按数据的实际位数输出;如果指定的输出宽度小于数据的实际位数,则突破域宽的限制,按实际位数输出;如果指定的域宽大于数据的实际位数,则默认在输出数据的左边输出空格,使输出的字符数等于列宽,也就是说,输出的数据在输出域中自动向右对齐。
width有以下三种情况:
n |
一个非负整型常数,指定输出占用n列宽度。 |
0n |
n为一个整型常数,输出占用n列,如果实际位数不足n列,数据前面补0,填满n列 |
* |
输出域宽来自待输出表达式前面的一个整型表达式。 |
printf("%*d", 8+1, -3);
c)[.precesion]
有以下4种情况:
缺省 |
对于f |e|E格式,表示小数点后输出6位小数,对于g |G格式,表示最多输出6位有效数字 |
.m |
m为非负整型常数,对于浮点格式,指定小数点后面输出m位小数; s格式,表示只输出字符串的前面m个字符 |
.0 |
对于f |e|E格式,表示不输出小数点和小数,按整数形式输出 |
.* |
表示precision来自待输出表达式前面的一个整型表达式 |
示例
#include "iostream" #include "stdio.h" using namespace std; int main() { double a=12.578,b=0.2572; int n=9,m=4; printf ( "%.2f,%10.2E,%f,%e,%10g" ,a,a,a,a,a); printf ( "\n" ); printf ( "a=%.0f,a=%*.*f" ,a,n,m,a); printf ( "\n" ); printf ( "%.2f%%" ,b*100); printf ( "\n" ); printf ( "%s%6s%6.3s" , "ABCD" , "ABCD" , "ABCD" ); return 1; } |
注意,输出中任何一个字符都算作一位。
d)[flag]
缺省 |
输出正数时不输出正号;域宽大于数据实际位数时,域中左边补空格,数据靠右对齐; |
+ |
输出正数时要输出正号; |
- |
域宽大于数据实际位数时,域中右边补空格,数据靠左对齐。 |
# |
用于x |X格式:输出0x(格式x)或0X(格式X)。 |
1、格式化输入函数scanf
用法: scanf("格式串" ,地址1,地址2,···);
1)格式符
syntax: %[*][width][h|l|L]type
(1) [h|l|L]type
d |
以十进制有符号整数形式转换输入数据 |
i |
以十进制有符号整数形式转换输入数据(同d格式) |
u |
以十进制无符号整数形式转换输入数据 |
o |
以八进制有符号整数形式转换输入数据 |
x |X |
以十六进制有符号整数形式转换输入数据(x和X等效) |
e|E|f|g|G |
以十进制浮点数形式转换输入数据,输入数据时,可以输入整型常量、小数形式实型常量或指数形式实型常量。 |
c |
输入一个字符(可输入控制字符) |
s |
输入字符串(遇到第一个空格、TAB或换行符结束转换) |
前缀修饰符:
L: 输入long double类型变量必加
l: 输入长整型变量或者double型变量必加
h: 输入短整型变量必加
(2) [width]
width字段用来指定输入数据的转换宽度,它必须是一个十进制非负整型常量。width表示读入多少个字符就结束本数据项的转换。如果没有指定width,则遇到空格 、TAB键、回车/换行符、非法输入则结束数据项的转换(%c格式除外)。
float a;int b;double c;
scanf("%f%3x%lf",&a,&b,&c);
若输入为:-1.5A8059¿
则a=-1.5, b=0xA80, c=59.0
(3) [*]号
表示数据输入项要按指定格式进行转换,但不保存变量,即该%没有对应的变量。
一般用%*c来吸收字符。
2、几点说明:
编译程序只是检查printf 函数的调用形式,不分析格式控制字符串,如果格式字符与输出项的类型不匹配,不进行类型转换。(输出的数为随机)
格式字符要用小写字母。
格式控制字符串中可以包含转义字符。
格式控制字符串中的普通字符则原样输出。
输出项的参数除了常数、变量外还可以是表达式、函数调用。
C语言中输入输出格式控制的更多相关文章
- C语言的printf输出格式控制
C语言的printf输出格式控制 printf大家都耳熟能详,但是能真正将其用法弄透的估计很少见. 转一篇,改天整理. 1.转换说明符 %a(%A) 浮点数.十六进制数字和p-(P-)记数法( ...
- C语言中输入输出函数
1.1.1 格式化输入输出函数Turbo C2.0 标准库提供了两个控制台格式化输入. 输出函数printf() 和scanf(), 这两个函数可以在标准输入输出设备上以各种不同的格式读写数据.pri ...
- C++: I/O流详解(二)——输入输出格式控制
一.格式控制 ios提供直接设置标志字的控制格式函数 iostream和iomanip库还提供了一批控制符简化I/O格式化操作 状态标志 值 含义 输入/输出 skipws 0X0001 跳过输入中的 ...
- Go语言中的流程控制
1 概述 Go语言提供了条件分支 if,状态分支 switch,循环 for,跳转 goto,延迟执行 defer,这些流程控制语句.分别作说明如下: 2 条件分支 if 依据条件是否满足确定执行哪个 ...
- c语言中的输入
先打个白条有时间在写 c语言中输入一行回车之后,以空格为单位进行的分割
- C语言中最常用的三种输入输出函数scanf()、printf()、getchar()和putchar()
本文给大家介绍C语言中最常用的三种输入输出函数scanf().printf().getchar()和putchar(). 一.scanf()函数格式化输入函数scanf()的功能是从键盘上输入数据,该 ...
- C语言输入输出格式符
C语言输入输出格式符 printf函数(格式输出函数) 1.一般格式 printf(格式控制,输出表列) 例如:printf("i=%d,ch=%c\n",i,ch); 说明: ( ...
- [ACM训练] ACM中巧用文件的输入输出来改写acm程序的输入输出 + ACM中八大输入输出格式
ACM中巧用文件的输入输出来改写acm程序的输入输出 经常有见大神们使用文件来代替ACM程序中的IO,尤其是当程序IO比较复杂时,可以使自己能够更专注于代码的测试,而不是怎样敲输入. C/C++代码中 ...
- C语言第一次作业——输入输出格式
题目1温度转换 本题要求编写程序,计算华氏温度150°F对应的摄氏温度.计算公式:C=5×(F−32)/9,式中:C表示摄氏温度,F表示华氏温度,输出数据要求为整型. 1.实验代码 #include& ...
随机推荐
- android ORMlite的应用
ORMLite -轻量级的对象关系映射(ORM) 如果你需要在android中使用ORMLite 你需要进入官方网站http://ormlite.com/ 中下载 下载了这两个包以后,你还需要在对应的 ...
- nginx redis tomcat 分布式web应用 session共享
目标:多台tomcat 使用redis实现共享session.redis的安装请参阅:centos上安装redis nginx 作为目前最流行的开源反向代理HTTP Server,用于实现资源缓存.w ...
- 仰视源代码,实现memcpy
C++实现内存的复制 通常我们使用深复制就是通过内存复制实现的,可是对象的复制涉及到基类派生类及其相关类的问题.这里不讨论. 目的为了可以明确内存复制的底层实现. void* memcpy(void* ...
- 【剑指Offer学习】【面试题19 :二叉树的镜像】
题目:请完毕一个函数,输入一个二叉树,该函数输出它的镜像. 二叉树结点的定义: /** * 二叉树的树结点 */ public static class BinaryTreeNode { int va ...
- Android(java)学习笔记150:为什么局部内部类只能访问外部类中的 final型的常量
为什么匿名内部类参数必须为final类型: 1) 从程序设计语言的理论上:局部内部类(即:定义在方法中的内部类),由于本身就是在方法内部(可出现在形式参数定义处或者方法体处),因而访问方法中的局部变 ...
- §12 循环101-while循环
§12 循环101-while循环 While和for具有一定的可替换性.语法如下: while test body continue终止当次循环,break退出整个循环. 注意while之后要用 ...
- java strtus2 DynamicMethodInvocation配置(二)
前面一章讲了下动态配置的方法.那样,能够直接动态的调用action里面的方法, 这里展示一种配置更少,更简洁的一种方法. 在前一章其他不变的情况下,改变配置文件 <package name=&q ...
- Linq常用查询运算符
Linq一共包含五十几个查询运算符,常用的根据类型来区分一共有5类左右,这五类里面一些事在项目查询中经常用到的.不过linq运算符的命名十分规范,基本从字面意思就能猜测出来是干嘛用的,下面我们挑选一些 ...
- JS实现各种页面的刷新
JS实现各种页面的刷新功能 1.刷新当前页面 opener.location.replace(opener.location.href); 或者window.opener.window.locatio ...
- Android开发之Handler
我们都知道应用程序开启后,安卓会开启一个主线程(UI线程),主线程管理UI控件,进行事件分发.那为什么会出现Handler呢? 例如你要是点击一个 Button ,Android会分发事件到Butto ...