格式化字符串
来源:互联网 发布:广州网络推广哪家好 编辑:程序博客网 时间:2024/05/22 13:08
字符串格式化命令,主要功能是把格式化的数据写入某个字符串中
1.sprintf:对多字节格式化的
int sprintf( char *buffer, constchar *format [,argument] ...);
返回值:buffer里面的数据的大小,不包括末尾的空’\0’
char buffer[MAX_PATH]="";
sprintf(buffer,"%s%d","ceshizifuchuan",100);
2.swprintf:双字节字符格式化的
int swprintf( wchar_t *buffer, constwchar_t *format [,argument] ...);
返回值:buffer里面的数据的大小,不包括末尾的空’\0’
wchar_t buffer[MAX_PATH]=L"";
swprintf(buffer,L"%s%d",L"ceshizifuchuan",100);
或者(有重载函数):
swprintf(buffer,MAX_PATH,L"%s%d",L"ceshizifuchuan",100);
3.wsprintf根据预定义指示符的不同可以对多字节/双字节字 符格式化。
int wsprintf( LPTSTR lpOut, // output buffer
LPCTSTR lpFmt, // format-control string
... // optional arguments);
返回值:buffer里面的数据的大小,不包括末尾的空’\0’
以下代码无论是ascii环境还是Unicode环境都可以正常运行:
TCHAR buffer[MAX_PATH]=TEXT("");
wsprintf(buffer,TEXT("%s%d"),TEXT("ceshizifuchuan"),100);
4. _snprintf最多从源串中拷贝n-1个字符到目标串中,然后再在后面加一个0。
int _snprintf( char*buffer, size_t count, const char*format [, argument] ...);
函数返回值:若成功则返回欲写入的字符串长度,若出错则返回负值。
char buffer[MAX_PATH]="";
_snprintf(buffer,3,"%s%d","ceshizifuchuan",100);
5. _snwprintf函数,_snprintf的Unicode版
6._sntprintf函数,_snprintf的通用版
小结:
1.在vc工程中设置多字节和Unicode对"ceshizifuchuan"这类字符串有有区别,对大部分函数的使用无区别,对通用数据类型TCHAR等通用函数wsprintf有作用。
=================================================================================================================================
表一 转换说明符及作为结果的打印输出
转换说明
输 出
%a
浮点数、十六进制数字和p-记数法 (C99)
%A
浮点数、十六进制数字和P-记数法 (C99)
%c
一个字符
%d
有符号十进制整数
%e
浮点数、e-记数法
%E
浮点数、E-记数法
%f
浮点数,十进制记数法
%g
根据数值不同自动选择%f或者%e。%e格式在指数小于-4或者大于等于精度时使用
%G
根据数值不同自动选择%f或者%E。%E格式在指数小于-4或者大于等于精度时使用
%i
有符号十进制整数 (与%d相同)
%o
无符号八进制整数
%p
指针(就是指地址)
%s
字符串
%u
无符号十进制整数
%x
使用十六进制数字0f 的无符号十六进制整数
%X
使用十六进制数字0F的无符号十六进制整数
%%
打印一个百分号
表二 printf() 修饰符
修饰符
意 义
标志
五种标志 (-、+、空格、# 和0) 都将在表三中描述,可以使用零个或多个标志
digit(s)
字段宽度的最小值。如果该字段不能容纳要打印的数或者字符串,系统会使用更宽的字段。示例:“%4d”
.digit(s)
精度。对于%e、%E和%f转换,是将要在小数点的右边打印的数字的位数。示例:“%5.2f”打印一个浮点数,他的字段宽度为5个字符,小数点后有两个数字。
h
和整数转换说明符一起使用,表示一个short int 或者 unsigned short int 类型数值。
示例:“%hu”、“%hx”和“%6.4hd”
hh
和整数转换说明符一起使用,表示一个signed char 或者unsigned char类型数值。
示例:“%hhu”、“%hhx”和“%6.4hhd”
j
和整数转换说明符一起使用,表示一个intmax_t或uintmax_t值。
示例:“%jd”和“%8jX”
l
和整数说明符一起使用,表示一个long int 或者unsigned long int 类型值。
示例:“%ld”和“%8lu”
ll
和整数说明符一起使用,表示一个long long int或 unsigned long long int 类型值 (C99)。
示例:“%lld”和“%8llu”
L
和浮点转换说明符一起使用,表示一个long double值。
示例:“%Lf”和“%10.4Le”
t
和整数转换说明符一起使用,表示一个ptrdiff_t值(与两个指针之间的差相对应的类型) (C99)
示例:“%td”和“%12ti”
z
和整数转换说明符一起使用,表示一个size_t值(sizeof返回的类型) (C99)。
示例:“%zd”和“%12zx”
表三 printf()的标志
修饰符
意 义
-
项目是左对齐的,也就是说,会把项目打印在字段的左侧开始处。示例:“%-20s”
+
有符号的值若为正,则显示带加号的符号;若为负,则带减号的符号。示例:“%+6.2f”
(空格)
有符号的值若为正,则显示时带前导空格(但是不显示符号);若为负,则带减号符号。+标志会覆盖空格标志。示例:“% 6.2f”
#
使用转换说明的可选形式。若为%o格式,则以0开始;若为%x和%X格式,则以0x或0X开始,对于所有的浮点形式,#保证了即使不限任何数字,也打印一个小数点字符。对于%g和%G格式,它防止尾随零被删除。示例:“%#o”、“%#8.0f”和“%+#10.3E”
0
对于所有的数字格式,用前导零而不是用空格填充字段宽度。如果出现-标志或者指定了精度(对于整数)则忽略该标志。示例:“%010d”和“%08.3f”
表四 ANSIC 中 scanf()的转换说明符
转换说明符
意 义
%c
把输入解释成一个字符
%d
把输入解释成一个有符号十进制整数
%e,%f,%g, %a
把输入解释成一个浮点数 (%a是C99标准)
%E,%F,%G,%A
把输入解释成一个浮点数 (%A是C99标准)
%i
把输入解释成一个有符号十进制整数
%o
把输入解释成一个有符号八进制数
%p
把输入解释成一个指针(地址)
%s
把输入解释成一个字符串;输入的内容以一个非空白字符作为开始,并且包含知道下一个空白字符的全部字符
%u
把输入解释成一个无符号十进制整数
%x,%X
把输入解释成一个有符号十六进制整数
- 格式化字符串
- 格式化字符串
- 格式化字符串
- 字符串格式化
- 格式化字符串
- 格式化字符串
- 字符串格式化
- 格式化字符串
- 字符串格式化
- 字符串格式化
- 字符串格式化
- 格式化字符串
- 格式化字符串
- 字符串格式化
- 格式化字符串
- 字符串格式化
- 字符串格式化
- 格式化字符串
- 20141005 【 DP 】 UVa 1289 Stacking Plates
- nyoj330
- poj 1659 Frogs' Neighborhood (判断简单图并输出)
- leetcode Sqrt(x)
- IP TCP UDP
- 格式化字符串
- SGU 210 Acdream 1227 Beloved Sons KM
- 开源GUI-Microwindows之程序入口分析
- 在命令行中运行eclipse中创建的java项目
- 八数码问题,初始局面和目标局面最少移动步数
- Swing 写的日期时间组件
- AFNetworking2.4.1解析
- UVa 557 - Burger (概率)
- java学习之时间复杂度