C语言sscanf,strstr和strtok函数用于字符提取分割

sscanf函数(提取字符):

#include <stdio.h>
int sscanf(const char *str, const char *format,[ argument ]...);

str:    待解析的字符串;
format: 字符串格式描述;
argument:是一序列数目不定的指针参数,存储解析后的数据.
返回值:成功转换的数据的个数

从输入字符串的左边开始往右匹配,遇到不符合匹配规则时则结束匹配。注意是遇到不符合描述规则时就结束,而不是从整个字符串中提取出符合规则的部分。

字符串格式描述说明:

* 表示匹配但是不显示/不读入;
^表示非,除什么之外;
[]表示一个字符集。
%c匹配单字符,
%s匹配字符串,
%d匹配十进制数字,
%f匹配浮点数等,
%[a-zA-Z]表示匹配任意字母,相应的可以改成只匹配大写或小写字母,
%[0-9]表示匹配任意数字,
%[1aA]表示匹配1,a,A中的任意一个。

代码示例:

整数转换//2022届08级09班
int Year,Grade, class;
int ret = sscanf("20220809", "%04d%02d%02d", &year, &Grade, &day);
printf("ret=%d, year=%d, Grade=%d, class%d/n", ret, year, Grade, class);

mac地址//00-23-63-9E-7F-33

int a,b,c,d,e,f;
int ret = sscanf("mac:00-23-63-9E-7F-33", "%*[^:]-%[^-]-%[^-]-%[^-]-%[^-]-%[^-]-%[^-]", &a, &b, &c,&d,&e,&f);

"%04d%02d%02d"是用来解析字符串的格式,%表示格式转换的开始,d表示转换为一个整数,04作为d的修饰,表示这是一个长度为4位的整数,不足4位时以0补齐。

例子返回结果等于3,表示有3个数据成功转换,转换成功数目同时取决于被解析的字符串以及其转换格式,如果我们把例子中的格式改为"%04d%02d",那么sscanf将只返回2,class的数值不会被sscanf更改。

 =====================================================

strstr函数(字符提取)

char *strstr( const char *str1, const char *str2 );

参数:
1.str1:要扫描的 C 字符串
2.str2:包含要匹配的字符序列的 C 字符串。
返回值:
指向 str1 中指定的整个字符序列在 str2 中首次出现的指针,如果序列在 str1 中不存在,则为 null 指针。

返回值:指向 str2 中第一次出现的 str1 的指针,如果 str2 不是 str1
的一部分,则返回一个空指针。匹配过程不包括终止空字符,但它到此为止。

代码示例:

​#include <stdio.h>
#include <string.h>
int main()
{
	char str1[] = { "07996KTFaabcskay" };
	char str2[] = { "abc" };
	char* ret = strstr(str1, str2);
	if (*ret != NULL)
		printf("%s", ret); 
	else
		printf("NOT FIND!");
	return 0;
}

​//打印出abcskay

=======================================================

strtok函数(字符分割)

char *strtok(char *str, const char *delim)
参数
str:要被分解的字符串
delim:用作分隔符的字符(可以是一个,也可以是集合)
返回值:该函数返回被分解的第一个子字符串,若无可检索的字符串,则返回空指针

代码示例:

 char str[80] = "08-F9-96-13-65-9P";
   const char s[2] = "-";   //字符串里可以是一个分隔符,也可以是分隔符的集合
   char *token;
   
   /* 获取第一个子字符串 */
   token = strtok(str, s);
     printf( "%s\n", token );//打印出08
   
   /* 继续获取其他的子字符串 */
   while( token != NULL ) {
      printf( "%s\n", token );
    
      token = strtok(NULL, s);
   }

  • 10
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

肖爱Kun

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值