大家晚上好,今天分享个源码吧,用在解析云端数据的。
说的好像很高大上,但是其实是很简单的,当然效率估计也不高,差不多就行了。
作用:其实就是字符串的查找,然后提对应字符串的数据出来。
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);
提取9位:
1rData=SearchNum(str,"AB=",50,3,&data,9);
那个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}
-
C语言
+关注
关注
180文章
7597浏览量
136119 -
源码
+关注
关注
8文章
633浏览量
29134 -
字符串
+关注
关注
1文章
577浏览量
20485
发布评论请先 登录
相关推荐
评论