c语言匹配八位字母字符,C语言字符串匹配和数据提取源码

大家晚上好,今天分享个源码吧,用在解析云端数据的。

说的好像很高大上,但是其实是很简单的,当然效率估计也不高,差不多就行了。

作用:其实就是字符串的查找,然后提对应字符串的数据出来。

随便创建一组数组,模拟单片机中接收的数据。

1charj='1'; 2str[0]='a'; 3str[1]='A'; 4str[2]='B'; 5str[3]='='; 6for(i=4;i<50;i++) 7     { 8        str[i] = j; 9        j++; 10     } 11    printf("开始 ");

然后找出搜寻字符串在数组中的位置,并且把字符串的后n位提取出来,我这是提取的是十进制数字。

1 rData=SearchNum(str,"AB=",50,3,&data,4); 2 3printf("rData=%d ",rData); 4 5printf("data=%d ",data);

下面的这句代码含义是:

对比str字符串中的与“AB=”匹配的字符串(长度必须匹配),然后提取其后4位,并且将提取到的数据 data 保存出来。

注:str的内容是:

1str=aAB=123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[]^@

1rData=SearchNum(str,"AB=",50,3,&data,4);

源码的实现:

1u16SearchNum(u8*inBuf,u8*searchBuf,u16dataLen,u8seachLen,unsignedlong*data,u8seachNumLen) 2{ 3u16i,rData; 4u8useData=0; 5i=0; 6//查找第一个字母 7for(;i!=dataLen;i++) 8{ 9if(inBuf[i]==searchBuf[0]) 10{ 11break; 12} 13} 14//比对长度 15rData=ibuffercmp(&inBuf[i],searchBuf,seachLen); 16if(rData==0) 17{ 18*data=GetSearchNum(&inBuf[i+seachLen],seachNumLen); 19 20returnrData+i; 21 22} 23return0; 24}

对比字符串长度的源码:

这种很简单啦!!!

1//检测buf1和buf2在规定的长度内是否相等 2uint8_tibuffercmp(uint8_t*buffer1,uint8_t*buffer2,uint16_tlen) 3{ 4while(len--) 5{ 6if(*buffer1!=*buffer2) 7{ 8return1; 9} 10buffer1++; 11buffer2++; 12} 13return0; 14}

还有一个内部调用的函数:

用来将字符转换成十进制的数字,根据要提取多少位来方便提取。

1staticunsignedlongGetSearchNum(u8*inBuf,u16seachLen) 2{ 3inti,k,j=seachLen; 4u8data1[seachLen]; 5unsignedlongdata2=0; 6unsignedlongnum=1; 7for(i=0;i 8{ 9if((*inBuf>='0')&&(*inBuf<= '9')) 10        { 11            num = 1; 12            k = seachLen-1; 13            for(k;k>0;k--) 14num*=10; 15data2+=(*inBuf-'0')*num; 16seachLen--; 17} 18inBuf++; 19} 20returndata2; 21}

测试结果:(提取4位)

1rData=SearchNum(str,"AB=",50,3,&data,4);

21671f403277c8202f7bf7146a4eda36.png

提取9位:

1rData=SearchNum(str,"AB=",50,3,&data,9);

40797c32fa00cfadb240dda362d4a8e0.png

那个rData = 1;是字符串“AB=”的首地址。

最后

这个源码在我之前写的解析云端数据并不是这样子的,具体怎么用,看大家的需求了,而且源码有一个很大的bug,就是无法搜索到下一个与“AB=”一样的字符串,应用并不是很大。当然能改进啊,看大家来改进了,假如字符串长度不匹配,可以进行重新查找,只需在不匹配的地方往后移动seachLen就好了。假如有多个一样的字符串,这可以用一个链表来保存这些数据。如字符串在原字符串中的位置,其后面的数据等等。

附上源码

1#include"stdio.h" 2 3typedefunsignedcharuint8_t; 4typedefunsignedshortintuint16_t; 5 6typedefunsignedcharu8; 7typedefunsignedshortintu16; 8 9//检测buf1和buf2在规定的长度内是否相等 10uint8_tibuffercmp(uint8_t*buffer1,uint8_t*buffer2,uint16_tlen) 11{ 12while(len--) 13{ 14if(*buffer1!=*buffer2) 15{ 16return1; 17} 18buffer1++; 19buffer2++; 20} 21return0; 22} 23 24staticunsignedlongGetSearchNum(u8*inBuf,u16seachLen) 25{ 26inti,k,j=seachLen; 27u8data1[seachLen]; 28unsignedlongdata2=0; 29unsignedlongnum=1; 30for(i=0;i31{ 32if((*inBuf>='0')&&(*inBuf<= '9')) 33        { 34            num = 1; 35            k = seachLen-1; 36            for(k;k>0;k--) 37num*=10; 38data2+=(*inBuf-'0')*num; 39seachLen--; 40} 41inBuf++; 42} 43returndata2; 44} 45 46u16SearchNum(u8*inBuf,u8*searchBuf,u16dataLen,u8seachLen,unsignedlong*data,u8seachNumLen) 47{ 48u16i,rData; 49u8useData=0; 50i=0; 51//查找第一个字母 52for(;i!=dataLen;i++) 53{ 54if(inBuf[i]==searchBuf[0]) 55{ 56break; 57} 58} 59//比对长度 60rData=ibuffercmp(&inBuf[i],searchBuf,seachLen); 61if(rData==0) 62{ 63*data=GetSearchNum(&inBuf[i+seachLen],seachNumLen); 64 65returnrData+i; 66 67} 68return0; 69} 70 71intmain() 72{ 73intrData,i; 74unsignedlongdata; 75u8str[50]; 76charj='1'; 77str[0]='a'; 78str[1]='A'; 79str[2]='B'; 80str[3]='='; 81for(i=4;i<50;i++) 82     { 83        str[i] = j; 84        j++; 85     } 86    printf("开始 "); 87 88    printf("str = %s ",str); 89    rData = SearchNum(str,"AB=",50,3,&data,9); 90 91    printf("rData = %d ",rData); 92 93    printf("data = %d ",data); 94}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值