蓝桥杯物联网竞赛_STM32L071KBU6_字符串处理

前言:

个人感觉国赛相较于省赛难度上升的点在于对于接收的字符串的处理,例如串口发送的字符串一般包含字母字符串 + 数字字符串,亦或者更复杂,对于LORA也是如此,传递的字符串如#9#1亦或者#1a#90,#1#12,如何将字符串中的数字信息快速高效的处理好,并赋值给我们需要的变量是及其重要的,国赛的功能更复杂时间更紧迫,那么高效处理这些复杂字符串是及其重要的

C字符串处理函数:

我认为最好的方法就是利用c自带的函数,站在前人的肩膀上才能看的更远

要想处理好这些字符串需要用到如下函数,用这些函数配合使用,能达到不一样的效果:

处理上述字符串避免不了的是将字符串切割,比较,数字字符转换成与之对应的数字

那么与之对应的c函数就是strncmp,memcpy,strtof,分别为比较函数,复制函数,字符串转浮点型函数

函数的用法和实例:

1、strncmp函数 [使用#include<string.h>库]:

str是string的缩写n指定比对的个数为n,cmp是compare比较的意思

strncmp可以指定比较的两个字符串的起始位置和比较区间

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

unsigned char a[10] = {'1', '\0', '2', '3', 'A'};
unsigned char b[10] = {'1', '\0', '2', '3', '9'};

int main(){
 	 printf("%d", strncmp(a + 2, b + 2, 2));
}

在这里插入图片描述

strcmp比对成功返回0否者返还非零

strcmp在比对'\0'后会停下:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

unsigned char a[4] = {'1', '\0', '2'};
unsigned char b[4] = {'1', '\0', '3'};

int main(){
 	 printf("%d", strncmp(a, b, 4));
}

在这里插入图片描述

2、memcpy [需要string.h库]:

mem是memory即内存的缩写cpy即copy即复制的缩写

memcpy能指定被复制对象的起点,以及要复制的长度,这个能复制'\0'

3、strtof [需要stdlib.h库]:

f是float的缩写

这个函数能将字符串转换成实际浮点型数据,停止的条件要么是不能再转换要么是转换完成

其第二个需要设置的参数是二级指针,这个有点特别,这个指针可以指向最后一个被转换的字符的后一个数,也就是说这个二级指针二级解析的值是终止字符'\0'的话说明全部转换成功,否者转换不成功,这个指针牛儿b之的地方在于其能最后判断字符数字是否合法例如'12'合法'1A2'不合法

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

char* a = "123";
char* b = "1A2";
char* p = NULL;
char* q = NULL;

int main(){
 
	strtof(a, &p);
	strtof(b, &q);
	if(*p == '\0') printf("a合法\n");
	else printf("a不合法\n");
	
	if(*q == '\0') printf("b合法\n");
	else printf("b不合法\n"); 
	return 0;
}

在这里插入图片描述

处理字符串实例:

判断字符串是不是以MAX和MIN开头,并判断MAX和MIN后面数字字符串是否合法,并转换:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
 
char a[20];
char* head1 = "MAX";
char* head2 = "MIN";

unsigned char temp[10];
unsigned char checkflag = 1;
 
int main(){
    scanf("%s", a);
    printf("%s\n", a);	
	char head[10];
	if(strncmp(a, head1, 3) * strncmp(a, head2, 3) == 0){
		printf("比对成功\n");
	}else{
		checkflag = 0;
		printf("比对失败\n");
	}
	
	if(checkflag == 1){
	   memcpy(head, a + 3, strlen(a) - 3); // 截取后面数字部分
       char* p;
	   float number = strtof(head, &p);
	   if(*p != '\0'){
	   	  printf("转换失败\n");
	   	  checkflag = 0;
	   }else{
	   	 printf("截取数字为:%.1f\n", number); 
	   }
	}
}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

接收多个数据并转换格式:#数据1#数据2

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

int main(){
 	char a[20];
	scanf("%s", a);
	char copy1[10];
	char copy2[10];
	unsigned char i = 1;
	unsigned char j = 0;
	while(a[i] != '#'){
		copy1[j ++] = a[i ++];
	}
	copy1[j] = '\0';
	i ++;
	j = 0;
	while(a[i] != '\0'){
		copy2[j ++] = a[i ++];
	}
	copy2[j] = '\0';
	printf("%s %s\n", copy1, copy2);
	char* p;
	float number1 = strtof(copy1, &p);
	char* q;
	float number2 = strtof(copy2, &q);
	if(*p == '\0' && *q == '\0'){
		printf("转换成功:%.1f && %.1f", number1, number2);
	}else{
		printf("%c %c\n", *p, *q);
		printf("转换失败"); 
	}	
}

在这里插入图片描述
在这里插入图片描述

  • 8
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值