大家晚上好,今天分享個源碼吧,用在解析云端數(shù)據(jù)的。
說的好像很高大上,但是其實是很簡單的,當(dāng)然效率估計也不高,差不多就行了。
作用:其實就是字符串的查找,然后提對應(yīng)字符串的數(shù)據(jù)出來。
隨便創(chuàng)建一組數(shù)組,模擬單片機(jī)中接收的數(shù)據(jù)。
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("開始 ");
然后找出搜尋字符串在數(shù)組中的位置,并且把字符串的后n位提取出來,我這是提取的是十進(jìn)制數(shù)字。
1 rData=SearchNum(str,"AB=",50,3,&data,4); 2 3printf("rData=%d ",rData); 4 5printf("data=%d ",data);
下面的這句代碼含義是:
對比str字符串中的與“AB=”匹配的字符串(長度必須匹配),然后提取其后4位,并且將提取到的數(shù)據(jù) data 保存出來。
注:str的內(nèi)容是:
1str=aAB=123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[]^@
1rData=SearchNum(str,"AB=",50,3,&data,4);
源碼的實現(xiàn):
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}
對比字符串長度的源碼:
這種很簡單啦?。。?/p>
1//檢測buf1和buf2在規(guī)定的長度內(nèi)是否相等 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}
還有一個內(nèi)部調(diào)用的函數(shù):
用來將字符轉(zhuǎn)換成十進(jìn)制的數(shù)字,根據(jù)要提取多少位來方便提取。
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}
測試結(jié)果:(提取4位)
1rData=SearchNum(str,"AB=",50,3,&data,4);
提取9位:
1rData=SearchNum(str,"AB=",50,3,&data,9);
那個rData = 1;是字符串“AB=”的首地址。
最后
這個源碼在我之前寫的解析云端數(shù)據(jù)并不是這樣子的,具體怎么用,看大家的需求了,而且源碼有一個很大的bug,就是無法搜索到下一個與“AB=”一樣的字符串,應(yīng)用并不是很大。當(dāng)然能改進(jìn)啊,看大家來改進(jìn)了,假如字符串長度不匹配,可以進(jìn)行重新查找,只需在不匹配的地方往后移動seachLen就好了。假如有多個一樣的字符串,這可以用一個鏈表來保存這些數(shù)據(jù)。如字符串在原字符串中的位置,其后面的數(shù)據(jù)等等。
附上源碼
1#include"stdio.h" 2 3typedefunsignedcharuint8_t; 4typedefunsignedshortintuint16_t; 5 6typedefunsignedcharu8; 7typedefunsignedshortintu16; 8 9//檢測buf1和buf2在規(guī)定的長度內(nèi)是否相等 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語言
+關(guān)注
關(guān)注
180文章
7608瀏覽量
137109 -
源碼
+關(guān)注
關(guān)注
8文章
646瀏覽量
29279 -
字符串
+關(guān)注
關(guān)注
1文章
584瀏覽量
20552
發(fā)布評論請先 登錄
相關(guān)推薦
評論