chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

C語(yǔ)言字符串匹配和數(shù)據(jù)提取源碼

黃工的嵌入式技術(shù)圈 ? 來(lái)源:黃工的嵌入式技術(shù)圈 ? 作者:黃工的嵌入式技術(shù) ? 2020-02-27 15:42 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

大家晚上好,今天分享個(gè)源碼吧,用在解析云端數(shù)據(jù)的。

說(shuō)的好像很高大上,但是其實(shí)是很簡(jiǎn)單的,當(dāng)然效率估計(jì)也不高,差不多就行了。

作用:其實(shí)就是字符串的查找,然后提對(duì)應(yīng)字符串的數(shù)據(jù)出來(lái)。

隨便創(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("開(kāi)始 ");

然后找出搜尋字符串在數(shù)組中的位置,并且把字符串的后n位提取出來(lái),我這是提取的是十進(jìn)制數(shù)字。

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

下面的這句代碼含義是:

對(duì)比str字符串中的與“AB=”匹配的字符串(長(zhǎng)度必須匹配),然后提取其后4位,并且將提取到的數(shù)據(jù) data 保存出來(lái)。

注:str的內(nèi)容是:

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

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

源碼的實(shí)現(xiàn):

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

對(duì)比字符串長(zhǎng)度的源碼:

這種很簡(jiǎn)單啦?。?!

1//檢測(cè)buf1和buf2在規(guī)定的長(zhǎng)度內(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}

還有一個(gè)內(nèi)部調(diào)用的函數(shù):

用來(lái)將字符轉(zhuǎn)換成十進(jìn)制的數(shù)字,根據(jù)要提取多少位來(lái)方便提取。

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}

測(cè)試結(jié)果:(提取4位)

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

提取9位:

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

那個(gè)rData = 1;是字符串“AB=”的首地址。

最后

這個(gè)源碼在我之前寫(xiě)的解析云端數(shù)據(jù)并不是這樣子的,具體怎么用,看大家的需求了,而且源碼有一個(gè)很大的bug,就是無(wú)法搜索到下一個(gè)與“AB=”一樣的字符串,應(yīng)用并不是很大。當(dāng)然能改進(jìn)啊,看大家來(lái)改進(jìn)了,假如字符串長(zhǎng)度不匹配,可以進(jìn)行重新查找,只需在不匹配的地方往后移動(dòng)seachLen就好了。假如有多個(gè)一樣的字符串,這可以用一個(gè)鏈表來(lái)保存這些數(shù)據(jù)。如字符串在原字符串中的位置,其后面的數(shù)據(jù)等等。

附上源碼

1#include"stdio.h" 2 3typedefunsignedcharuint8_t; 4typedefunsignedshortintuint16_t; 5 6typedefunsignedcharu8; 7typedefunsignedshortintu16; 8 9//檢測(cè)buf1和buf2在規(guī)定的長(zhǎng)度內(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//查找第一個(gè)字母 52for(;i!=dataLen;i++) 53{ 54if(inBuf[i]==searchBuf[0]) 55{ 56break; 57} 58} 59//比對(duì)長(zhǎng)度 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("開(kāi)始 "); 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}

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • C語(yǔ)言
    +關(guān)注

    關(guān)注

    183

    文章

    7634

    瀏覽量

    143871
  • 源碼
    +關(guān)注

    關(guān)注

    8

    文章

    678

    瀏覽量

    30833
  • 字符串
    +關(guān)注

    關(guān)注

    1

    文章

    594

    瀏覽量

    22892
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    labview如何生成一個(gè)帶字符串返回的dll

    labview如何生成一個(gè)dll,如下圖,要求一個(gè)輸入,類(lèi)型是字符串,返回類(lèi)型也是字符串
    發(fā)表于 08-28 23:20

    在Python中字符串逆序有幾種方式,代碼是什么

    對(duì)于一個(gè)給定的字符串,逆序輸出,這個(gè)任務(wù)對(duì)于python來(lái)說(shuō)是一種很簡(jiǎn)單的操作,畢竟強(qiáng)大的列表和字符串處理的一些列函數(shù)足以應(yīng)付這些問(wèn)題 了,今天總結(jié)了一下python中對(duì)于字符串的逆序輸出的幾種常用
    的頭像 發(fā)表于 08-28 14:44 ?408次閱讀

    SQL 通用數(shù)據(jù)類(lèi)型

    如何與存儲(chǔ)的數(shù)據(jù)進(jìn)行交互。 下面的表格列出了 SQL 中通用的數(shù)據(jù)類(lèi)型: 數(shù)據(jù)類(lèi)型 描述 CHARACTER(n) 字符/字符串。固定長(zhǎng)度
    的頭像 發(fā)表于 08-18 09:46 ?463次閱讀

    harmony-utils之StrUtil,字符串工具類(lèi)

    harmony-utils之StrUtil,字符串工具類(lèi) harmony-utils 簡(jiǎn)介與說(shuō)明 [harmony-utils] 一款功能豐富且極易上手的HarmonyOS工具庫(kù),借助眾多實(shí)用工具類(lèi)
    的頭像 發(fā)表于 07-03 11:32 ?256次閱讀

    《ESP32S3 Arduino開(kāi)發(fā)指南》第三章 C/C++語(yǔ)言基礎(chǔ)

    ++基礎(chǔ),由于篇幅有限,在此僅對(duì)C/C++語(yǔ)言基礎(chǔ)進(jìn)行簡(jiǎn)單介紹。本章將分為如下9個(gè)小節(jié):3.1 數(shù)據(jù)類(lèi)型3.2 運(yùn)算符3.3 表達(dá)式3.4 數(shù)組3.5
    發(fā)表于 06-10 09:20

    STM32C031C6使用的是UART2通訊,通過(guò)printf()函數(shù)發(fā)送字符串時(shí),漢字錯(cuò)碼怎么解決?

    使用的是UART2通訊,通過(guò)printf()函數(shù)發(fā)送字符串時(shí),漢字錯(cuò)碼(見(jiàn)下圖),應(yīng)該是KEIL哪里沒(méi)有設(shè)置好的問(wèn)題。 啟用了UART2的中斷接收,可以接收到串口調(diào)試助手的數(shù)據(jù),但是緩存區(qū)的指針沒(méi)有歸零,下次接收時(shí)緩存區(qū)中的內(nèi)容接續(xù)(如下圖所示),不知道用什么命令來(lái)清除
    發(fā)表于 03-07 12:30

    字符串數(shù)據(jù)庫(kù)中的存儲(chǔ)方式

    數(shù)據(jù)庫(kù)是現(xiàn)代信息技術(shù)中存儲(chǔ)和管理數(shù)據(jù)的核心組件。字符串作為最常見(jiàn)的數(shù)據(jù)類(lèi)型之一,在數(shù)據(jù)庫(kù)中的存儲(chǔ)方式對(duì)其性能和可擴(kuò)展性有著重要影響。
    的頭像 發(fā)表于 01-07 15:41 ?1140次閱讀

    字符串在編程中的應(yīng)用實(shí)例

    字符串在編程中有著廣泛的應(yīng)用,它們被用于表示文本數(shù)據(jù)、處理用戶(hù)輸入、構(gòu)建動(dòng)態(tài)內(nèi)容等。以下是一些字符串在編程中的應(yīng)用實(shí)例: 1. 用戶(hù)輸入與輸出 用戶(hù)輸入 :程序通常需要從用戶(hù)那里獲取輸入,這些輸入通
    的頭像 發(fā)表于 01-07 15:33 ?937次閱讀

    字符串字符數(shù)組的區(qū)別

    在編程語(yǔ)言中,字符串字符數(shù)組是兩種基本的數(shù)據(jù)結(jié)構(gòu),它們都用于存儲(chǔ)和處理文本數(shù)據(jù)。盡管它們?cè)诠δ苌嫌幸欢ǖ闹丿B,但在內(nèi)部表示、操作方式和使用
    的頭像 發(fā)表于 01-07 15:29 ?1506次閱讀

    字符串反轉(zhuǎn)的實(shí)現(xiàn)方式

    在編程中,字符串反轉(zhuǎn)是一個(gè)基礎(chǔ)而重要的操作,它涉及到將一個(gè)字符串中的字符順序顛倒過(guò)來(lái)。這個(gè)操作在多種編程語(yǔ)言中都有不同的實(shí)現(xiàn)方式,本文將探討幾種常見(jiàn)的
    的頭像 發(fā)表于 01-07 15:27 ?1076次閱讀

    字符串處理方法 字符串轉(zhuǎn)數(shù)字的實(shí)現(xiàn)

    在編程中,將字符串轉(zhuǎn)換為數(shù)字是一個(gè)常見(jiàn)的需求。不同的編程語(yǔ)言有不同的方法來(lái)實(shí)現(xiàn)這一功能。以下是一些常見(jiàn)編程語(yǔ)言中的字符串轉(zhuǎn)數(shù)字的實(shí)現(xiàn)方法: Python 在Python中,可以使用內(nèi)置
    的頭像 發(fā)表于 01-07 15:26 ?1227次閱讀

    C語(yǔ)言筆試題

    ("this is g ..."); return 2;}int main(){ printf("%d %d", f(), g()); return 0;} 代碼很簡(jiǎn)單,函數(shù) f 輸出一個(gè)字符串,返回整數(shù) 1
    的頭像 發(fā)表于 12-30 09:48 ?581次閱讀

    字符串處理:4G模組軟件指南精要!

    最近一直有朋友咨詢(xún)我關(guān)于4G模組的字符串處理,今天我便把相關(guān)指南展示給大家。
    的頭像 發(fā)表于 11-17 09:57 ?737次閱讀
    <b class='flag-5'>字符串</b>處理:4G模組軟件指南精要!

    base64字符串轉(zhuǎn)換為二進(jìn)制文件

    一些編程知識(shí)。以下是將Base64字符串轉(zhuǎn)換為二進(jìn)制文件的一般步驟,以及一個(gè)簡(jiǎn)單的Python示例代碼。 步驟: 獲取Base64字符串 :首先,你需要有一個(gè)Base64編碼的字符串。 解碼Base64
    的頭像 發(fā)表于 11-10 10:55 ?3372次閱讀

    labview中浮點(diǎn)數(shù)與十六進(jìn)制字符串相互轉(zhuǎn)化

    與下位機(jī)數(shù)據(jù)交流及通訊時(shí),經(jīng)常有浮點(diǎn)數(shù)與十六進(jìn)制字符串相互轉(zhuǎn)化的需求,經(jīng)過(guò)兩天總結(jié),找到了最簡(jiǎn)潔的相互轉(zhuǎn)化的方法,萌新歡迎大佬指正,文件也附上。*附件:HEX字符串與浮點(diǎn)數(shù)轉(zhuǎn)換.rar
    發(fā)表于 10-21 19:51