声明:本人所写博客是在大量阅读别人的博客以及自己的经验基础上写出来的,既有转载别人的,也有自己平时学习工作的心得,写出来与大家共享,希望大家能够指出其中的错误以及不足之处,多多交流,共同进步。我主要做嵌入式,如需交流的话,请加QQ群:88459451(linux学习交流群)
Linux常用C函数—字符串转换
atof(将字符串转换成浮点型数)
相关函数 atoi,atol,strtod,strtol,strtoul
表头文件 #include <stdlib.h>
定义函数 double atof(const char *nptr);
函数说明 atof()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('\0')才结束转换,并将结果返回。参数nptr字符串可包含正负号、小数点或E(e)来表示指数部分,如123.456或123e-2。
返回值 返回转换后的浮点型数。
附加说明 atof()与使用strtod(nptr,(char**)NULL)结果相同。
程序实例:/* 将字符串a 与字符串b转换成数字后相加*/
#include<stdlib.h>
#include<stdio.h>
int main()
{ char *a="-100.23";
char *b="200e-2";
float c;
c=atof(a)+atof(b);
printf("c=%.2f\n",c);
return 0;
}VC++ 6.0 执行结果:c=-98.23
atoi(将字符串转换成整型数)
相关函数 atof,atol,atrtod,strtol,strtoul
表头文件 #include<stdlib.h>
定义函数 int atoi(const char *nptr);
函数说明 atoi()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做
转换,而再遇到非数字或字符串结束时('\0')才结束转换,并将结果返回。
返回值 返回转换后的整型数。
附加说明 atoi()与使用strtol(nptr,(char**)NULL,10);结果相同。
程序实例/* 将字符串a 与字符串b转换成数字后相加*/
#include<stdlib.h>
#include<stdio.h>
int main()
{ char a[]="-100";
char b[]="456";
int c;
c=atoi(a)+atoi(b);
printf("c=%d\n",c);
return 0;
} VC++ 6.0 执行结果:c=356
atol(将字符串转换成长整型数)
相关函数 atof,atoi,strtod,strtol,strtoul
表头文件 #include<stdlib.h>
定义函数 long atol(const char *nptr);
函数说明 atol()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做
转换,而再遇到非数字或字符串结束时('\0')才结束转换,并将结果返回。
返回值 返回转换后的长整型数。
附加说明 atol()与使用strtol(nptr,(char**)NULL,10);结果相同。
程序实例:/*将字符串a与字符串b转换成数字后相加*/
#include<stdlib.h>
#include<stdio.h>
int main()
{
char a[]="1000000000";
char b[]="234567890";
long c;
c=atol(a)+atol(b);
printf("c=%d\n",c);
return 0;
}
VC++ 6.0 执行结果:c=1234567890
gcvt(将浮点型数转换为字符串,取四舍五入)
相关函数 ecvt,fcvt,sprintf
表头文件 #include<stdlib.h>
定义函数 char *gcvt(double number,size_t ndigits,char *buf);
函数说明 gcvt()用来将参数number转换成ASCII码字符串,参数ndigits表示显示的位数。gcvt()与ecvt()和fcvt()不同的地方在于,gcvt()所转换后的字符串包含小数点或正负符号。若转换成功,转换后的字符串会放在参数buf指针所指的空间。
返回值 返回一字符串指针,此地址即为buf指针。
程序实例1:
#include<stdlib.h>
#include<stdio.h>
int main()
{ double a=123.45;
double b=-1234.56;
char ptr[25];此处25换作3、5结果不变
gcvt(a,5,ptr);
printf("a value=%s\n",ptr);
gcvt(b,6,ptr);
printf("b value=%s\n",ptr);
return 0;
} VC++ 6.0通过,执行结果:
程序实例2
#include <stdlib.h>
#include <stdio.h>
int main(void)
{ char str[25];
double num;
int sig = 5; /* significant digits */
/* a regular number */
num = 9.876;
gcvt(num, sig, str);
printf("string = %s\n", str);
/* a negative number */
num = -123.4567;
gcvt(num, sig, str);
printf("string = %s\n", str);
/* scientific notation */
num = 0.678e5;
gcvt(num, sig, str);
printf("string = %s\n", str);
return(0);
} VC++ 6.0通过,执行结果:
strtod(将字符串转换成浮点数)
相关函数 atoi,atol,strtod,strtol,strtoul
表头文件 #include<stdlib.h>
定义函数 double strtod(const char *nptr,char **endptr);
函数说明 strtod()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做
转换,到出现非数字或字符串结束时('\0')才结束转换,并将结果返回。若endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr传回。参数nptr字符串可包含正负号、小数点或E(e)来表示指数部分。如123.456或123e-2。
返回值 返回转换后的浮点型数。
附加说明 参考atof()。
程序实例1
#include<stdlib.h>
#include<stdio.h>
int main()
{
char a[]="1000000000";
char b[]="1000000000";
char c[]="ffff";
printf("a=%lf\n",strtod(a,NULL));
printf("b=%lf\n",strtod(b,NULL));
printf("c=%lf\n",strtod(c,NULL));
return 0;
}
VC++ 6.0通过,执行结果:
程序实例2
#include<stdlib.h>
#include<stdio.h>
int main()
{ char *endptr;
char a[]="12345.6789";
char b[]="1234.567qwer";
char c[]="-232.23e4";
printf("a=%lf\n",strtod(a,NULL));
printf("b=%lf\n",strtod(b,&endptr));
printf("endptr=%s\n",endptr);
printf("c=%lf\n",strtod(c,NULL));
return 0;
} VC++ 6.0通过,执行结果:
strtol(将字符串转换成长整型数)
相关函数 atof,atoi,atol,strtod,strtoul
表头文件 #include<stdlib.h>
定义函数 long int strtol(const char *nptr,char **endptr,int base);
函数说明 strtol()会将参数nptr字符串根据参数base来转换成长整型数。参数base范围从2至36,或0。
参数base代表采用的进制方式,如base值为10则采用10进制,若base值为16则采用16进制等。当base值为0时则是采用10进制做转换,但遇到如'0x'前置字符则会使用16进制做转换。一开始strtol()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,再遇到非数字或字符串结束时('\0')结束转换,并将结果返回。若参数endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr返回。
返回值 返回转换后的长整型数,否则返回ERANGE并将错误代码存入errno中。
附加说明 ERANGE指定的转换字符串超出合法范围。
程序实例1 /* 将字符串a,b,c 分别采用10,2,16进制转换成数字*/
#include<stdlib.h>
#include<stdio.h>
int main()
{ char a[]="1000000000";
char b[]="1000000000";
char c[]="ffff";
printf("a=%d\n",strtol(a,NULL,10));
printf("b=%d\n",strtol(b,NULL,2));
printf("c=%d\n",strtol(c,NULL,16));
return 0;
} VC++ 6.0通过,执行结果:
strtoul(将字符串转换成无符号长整型数)
相关函数 atof,atoi,atol,strtod,strtol
表头文件 #include<stdlib.h>
定义函数 unsigned long int strtoul(const char *nptr,char **endptr,int base);
函数说明 strtoul()会将参数nptr字符串根据参数base来转换成无符号的长整型数。参数base范围从2至36,或0。参数base代表采用的进制方式,如base值为10则采用10进制,若base值为16则采用16进制数等。当base值为0时则是采用10进制做转换,但遇到如'0x'前置字符则会使用16进制做转换。一开始strtoul()会扫描参数nptr字符串,跳过前面的空格字符串,直到遇上数字或正负符号才开始做转换,再遇到非数字或字符串结束时('\0')结束转换,并将结果返回。若参数endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr返回。
返回值 返回转换后的长整型数,否则返回ERANGE并将错误代码存入errno中。
附加说明 ERANGE指定的转换字符串超出合法范围。
程序实例
#include<stdlib.h>
#include<stdio.h>
int main()
{ char a[]="1000000000";
char b[]="1000000000";
char c[]="ffff";
printf("a=%d\n",strtoul(a,NULL,10));
printf("b=%d\n",strtoul(b,NULL,2));
printf("c=%d\n",strtoul(c,NULL,16));
return 0;
} VC++ 6.0通过,执行结果:
toascii(将整型数转换成合法的ASCII 码字符)
相关函数 isascii,toupper,tolower
表头文件 #include<ctype.h>
定义函数 int toascii(int c)
函数说明 toascii()会将参数c转换成7位的unsigned char值,第八位则会被清除,此字符即会被转成
ASCII码字符。
返回值 将转换成功的ASCII码字符值返回。
程序实例1
#include<stdlib.h>
#include<stdio.h>
int main()
{
int a=217;
char b;
printf("before toascii () : a value =%d(%c)\n",a);
b=toascii(a);
printf("after toascii() : a value =%d(%c)\n",b);
return 0;
}
tolower(将大写字母转换成小写字母)
相关函数 isalpha,toupper
表头文件 #include<stdlib.h>
定义函数 int tolower(int c);
函数说明 若参数c为大写字母则将该对应的小写字母返回。
返回值 返回转换后的小写字母,若不须转换则将参数c值返回。
程序实例: /* 将s字符串内的大写字母转换成小写字母*/
#include<ctype.h>
#include<stdio.h>
int main()
{
char s[]="aBcDeFgH12345;!#$";
int i;
printf("before tolower() : %s\n",s);
for(i=0;i<sizeof(s);i++)
s[i]=tolower(s[i]);
printf("after tolower() : %s\n",s);
return 0;
} VC++ 6.0通过,执行结果:
toupper(将小写字母转换成大写字母)
相关函数 isalpha,tolower
表头文件 #include<ctype.h>
定义函数 int toupper(int c);
函数说明 若参数c为小写字母则将该对映的大写字母返回。
返回值 返回转换后的大写字母,若不须转换则将参数c值返回。
程序实例:
#include<ctype.h>
#include<stdio.h>
int main()
{
char s[]="aBcDeFgH12345;!#$";
int i;
printf("before toupper() : %s\n",s);
for(i=0;i<sizeof(s);i++)
s[i]=toupper(s[i]);
printf("after toipper() : %s\n",s);
return 0;
} VC++ 6.0通过,执行结果:
Ecvt函数
头文件:#include< stdlib.h>
功能:将双精度浮点型数转换为字符串,转换结果中不包括十进制小数点。
用法: char* ecvt(double value, int ndigit, int *decpt, int *sign);
参 数: value:待转换的双精度浮点数;ndigit:存储的有效数字位数;
*decpt:存储的小数点位置;*sign:转换的数的符号;返回值:char*:指向生成的字符串。
详细解释:ecvt函数把一个双精度浮点数转换成一个字符串。value参数是要转换的浮点数。这个函数存储最多ndigit个数字值作为一个字符串,并添加一个空数字符('\0'),如果value中的数字个数超过ndigit,低位数字被舍入。如果少于ndigit个数字,该字符串用0填充。 只有数字才存储在该字符串中,小数点位置和value符号在调用之后从decpt和sign获取。decpt参数指出给出小数点位置的整数值, 它是从该字符串的开头位置计算的。0或负数指出小数点在第一个数字的左边。sign参数指出一个指出转换的数的符号的整数。如果该整数为0,这个数为正数,否则为负数。
程序实例
#include <stdlib.h>
#include <stdio.h>
#include <conio.h>
int main(void)
{
char *string;
double value;
int dec, sign;
int ndig = 10;
//clrscr();
system("cls");
value = 9.876;
string = ecvt(value, ndig, &dec, &sign);
printf("string = %s dec = %d \nsign = %d\n", string, dec, sign);
value = -123.45;
ndig= 15;
string = ecvt(value,ndig,&dec,&sign);
printf("string = %s dec = %d sign = %d\n",string, dec, sign);
value = 0.6789e5; /* scientific notation */
ndig = 5;
string = ecvt(value,ndig,&dec,&sign);
printf("string = %s dec = %d\nsign = %d\n", string, dec, sign);
return 0;
} VC++ 6.0通过,执行结果:
fcvt函数
功 能: 把一个浮点数转换为字符串
用法: char *fcvt(double value, int ndigit, int *decpt, int *sign);
参数:value:要转换的浮点数,输入参数;ndigit:小数点后面的位数,输入参数;
decpt:表示小数点的位置,输出参数;sign:表示符号,0为正数,1为负数,输出参数;
程序实例
#include <stdlib.h>
#include <stdio.h>
#include <conio.h>
int main(void)
{
char *string;
double value;
int dec, sign;
int ndig = 10;
system("cls");
value = 9.876;
string = fcvt(value, ndig, &dec, &sign);
printf("string = %s dec = %d \nsign = %d\n", string, dec, sign);
value = -123.45;
ndig= 15;
string = fcvt(value,ndig,&dec,&sign);
printf("string = %s dec = %d sign = %d\n",string, dec, sign);
value = 0.6789e5; /* scientific notation */
ndig = 5;
string = fcvt(value,ndig,&dec,&sign);
printf("string = %s dec = %d\nsign = %d\n", string, dec, sign);
return 0;
} VC++ 6.0通过,执行结果:
Sprintf函数
头文件:#include<stdio.h>
功能:把格式化的数据写入某个字符串。
函数原型:int sprintf( char *buffer, const char *format [, argument] … );
返回值:字符串长度(strlen)
sprintf格式的规格如下所示。[]中的部分是可选的。
%[指定参数][标识符][宽度][.精度]指示符
若想输出‘%'本身时, 请这样“%%”处理。
1. 处理字符方向。负号时表示从后向前处理。
2. 填空字元。0的话表示空格填0;空格是内定值,表示空格就放着。
3. 字符总宽度。为最小宽度。
4. 精确度。指在小数点后的浮点数位数。
%% 印出百分比符号,不转换。
%c 整数转成对应的 ASCII 字元。
%d 整数转成十进位。
%f 倍精确度数字转成浮点数。
%o 整数转成八进位。
%s 整数转成字符串。
%x 整数转成小写十六进位。
%X 整数转成大写十六进位。
程序实例1
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
int main()
{
srand(time(0));
char s[64];
int offset = 0;
for(int i = 0; i < 10; i++)
{
offset += sprintf(s + offset, "%d,", rand() % 100);
}
s[offset - 1] = '\n';//将最后一个逗号?成?行符
printf(s);
return 0;
} VC++ 6.0通过,执行结果:
程序实例2
#include<stdio.h>
int main(void)
{
char buffer[200], s[] = "computer", c = 'l';
int i = 35, j;
float fp = 1.7320534f; // Format and print various data:
j = sprintf( buffer, " String: %s\n", s ); // C4996
j += sprintf( buffer + j, " Character: %c\n", c ); // C4996
j += sprintf( buffer + j, " Integer: %d\n", i ); // C4996
j += sprintf( buffer + j, " Real: %f\n", fp );// C4996
// Note: sprintf is deprecated; consider using sprintf_s instead
printf( "Output:\n%s\ncharacter count = %d\n", buffer, j );
return 0;
} VC++ 6.0通过,执行结果: