1、sprintf()
根据参数 format
字符串来转换并格式化数据,然后将结果输出到 str 指定的空间中, 直到出现字符串结束符 ‘\0’
为止。代码如下,
#include<stdio.h> #include<stdlib.h> #include<string.h> int main() { /* int sprintf(char *_CRT_SECURE_NO_WARNINGS, const char *format, ...); 参数 str:字符串首地址 format:字符串格式,用法和 printf()一样 返回值 成功:实际格式化的字符个数 失败:-1 */ //1. 格式化字符串 char buf[1024] = { 0 }; sprintf(buf, "你好,%s,", "cjavapy"); printf("buf:%s\n",buf); memset(buf, 0, 1024); sprintf(buf, "我今年%d", 5); printf("buf:%s\n", buf); //2. 拼接字符串 memset(buf, 0, 1024); char str1[] = "hello"; char str2[] = "world"; int len = sprintf(buf,"%s %s",str1,str2); printf("buf:%s len:%d\n", buf,len); //3. 数字转字符串 memset(buf, 0, 1024); int num = 100; int f1 = 100.111; sprintf(buf, "%d", num); memset(buf, 0, 1024); int f2 = 100.111; sprintf(buf, "%f", f2); printf("buf:%s\n", buf); //4. 设置对齐与输出格式 //设置宽度 右对齐 memset(buf, 0, 1024); sprintf(buf, "%8d", num); printf("buf:%s\n", buf); //设置宽度 左对齐 memset(buf, 0, 1024); sprintf(buf, "%-8d", num); printf("buf:%s\n", buf); //转成16进制字符串 小写 memset(buf, 0, 1024); sprintf(buf, "0x%x", num); printf("buf:%s\n", buf); //转成8进制字符串 memset(buf, 0, 1024); sprintf(buf, "0%o", num); printf("buf:%s\n", buf); return 0; }
2、sscanf()
从 str 指定的字符串读取数据,并根据参数 format 字符串来转换并格式化数据。代码如下,
#include <stdio.h> #include <string.h> int main () { /* int sscanf(const char *str, const char *format, ...); 参数 str:指定的字符串首地址 format:字符串格式,用法和 scanf()一样 返回值 成功:参数数目,成功转换的值的个数 失败: - 1 */ /* //* 亦可用于格式中, (即 %*d 和 %*s) 加了星号 (*) 表示跳过此数据不读入. (也就是不把此数据读入参数中)*/ const char *p1 = "abcd123"; char buf1[32] = { 0 }; sscanf(p1, "%*[a-z]%s", buf1); //跳过字母 printf("-- buf1[%s]--\n", buf1); //[a|b|c]表示a,b,c中选一 const char *p2 = "3b"; char buf2_1[32] = { 0 }; char buf2_2[32] = { 0 }; sscanf(p2, "%[1|2|3]%c", buf2_1, buf2_2); //或运算符使用 printf("-- buf1[%s]--buf2_2[%s]---\n", buf2_1, buf2_2); //[d],表示可以有d也可以没有d。 const char *p3 = "b"; char buf3_1[32] = { 0 }; char buf3_2[32] = { 0 }; sscanf(p3, "%[3]%c", buf3_1, buf3_2); //无法提取任何数据 printf("-- buf1[%s]--buf2_2[%s]---\n", buf3_1, buf3_2); //[d],表示可以有d也可以没有d。 const char *p4 = "b"; char buf4_1[32] = { 0 }; char buf4_2[32] = { 0 }; sscanf(p4, "%c%[3]", buf4_1, buf4_2); //可以正常提取b printf("-- buf1[%s]--buf2_2[%s]---\n", buf4_1, buf4_2); //结论:sscanf提取字符串必须知道字符串的具体格式,使用上不如正则灵活 //width表示读取宽度。 const char *p5 = "abcdef123"; char buf5_1[32] = { 0 }; char buf5_2[32] = { 0 }; sscanf(p5, "%3s%s", buf5_1, buf5_2); //%3s 表示提取3个字符的字符串 printf("-- buf1[%s]--buf2_2[%s]---\n", buf5_1, buf5_2); // h|I|I64 是配合%d提取整数使用 L 是配合%f提取浮点数使用,h表示short类型数据,I表示int类型数据,I64表示长整型数据 const char *p6 = "123578abc"; int buf6_1; char buf6_2[32] = { 0 }; sscanf(p6, "%Id%s", &buf6_1, buf6_2); printf("-- buf1[%d]--buf2_2[%s]---\n", buf6_1, buf6_2); //控制字符 // %c 一个单一的字符 // %d 一个十进制整数 // %i 一个整数 // %e, %f, %g 一个浮点数 // %o 一个八进制数 // %s 一个字符串 // %x 一个十六进制数 // %p 一个指针 // %n 一个等于读取字符数量的整数 // %u 一个无符号整数 // %[] 一个字符集 // %% 一个精度符号 const char *p7 = "123578abc"; char ch7 = 0; char buf7_2[32] = { 0 }; sscanf(p7, "%c%s", &ch7, buf7_2); printf("-- buf1[%c]--buf2_2[%s]---\n", ch7, buf7_2); //sscanf函数遇到空格停止读取字符串,所有需要特地注明空格 const char *p8 = "123 578a bc"; char buf8_1[32] = { 0 }; char buf8_2[32] = { 0 }; sscanf(p8, "%s%*[ ]%s", buf8_1,buf8_2); //格式化里有空格,可以提取 printf("-- buf1[%s]--buf2_2[%s]---\n", buf8_1, buf8_2); //^ 取到指定字符为止的字符串 const char *p9 = "123abc"; char buf9_1[32] = { 0 }; char buf9_2[32] = { 0 }; sscanf(p9, "%[^2]%s", buf9_1,buf9_2); printf("-- buf1[%s]--buf2_2[%s]---\n", buf9_1, buf9_2); //截取到指定字符串 "3ab" const char *p10 = "12-3ab-c"; char buf10_1[32] = { 0 }; char buf10_2[32] = { 0 }; sscanf(p10, "%*[^-]-%[^-]%s", buf10_1, buf10_2); printf("-- buf1[%s]--buf2_2[%s]---\n", buf10_1, buf10_2); return(0); }