C++解析特殊符號(hào)tab、換行符號(hào)實(shí)例代碼
前言:
我們經(jīng)常會(huì)遇到一些Linux內(nèi)核信息需要,比如一個(gè)wifi數(shù)據(jù),中間是用tab鍵盤隔開的,然后每一行用換行符進(jìn)行區(qū)分,如下所示的數(shù)據(jù)

第一位置是:wifi名稱 第二個(gè)位置是:信號(hào)強(qiáng)度 第三個(gè)位置是:信號(hào)類型2.4Ghz或者5Ghz 第四個(gè)位置是:加密類型 第五個(gè)類型是:MAC地址
遇到這樣的數(shù)據(jù),我們比較常見的C函數(shù)解析是用while循環(huán)去匹配字符串里面的'\t'(tab鍵),'\n'(換行符號(hào))等,然后用C標(biāo)準(zhǔn)庫(kù)里面str函數(shù),例如strncpy進(jìn)行復(fù)制或者strstr去查找,類似于下面所示:
int i, j ;
i = 0;
j = strlen(strIn) - 1;
while(strIn[i] == ' ' || strIn[i] == '\t')
++i;
while(strIn[j] == ' ' || strIn[j] == '\t')
--j;
strncpy(strOut, strIn + i , j - i + 1);
那么我們?cè)趺从肅++解析呢,最近剛好解析了部分wifi信息,所以給大家分享哈這部分。
解析代碼
對(duì)應(yīng)上面的wifi信息的表,我們看到了一行有五個(gè)數(shù)據(jù),這時(shí)候打包收到了一個(gè)string類型的wifi信息。
第一件事情,我們先確認(rèn)好解析的范圍,即知道最開始一位和最后一位,設(shè)置好recivemsg.begin 和 recivemsg.
第二件事情,進(jìn)行識(shí)別tab符號(hào)和換行符號(hào)之后進(jìn)行分段
第三件事情,把分好的數(shù)據(jù)塞到一個(gè)vector容器里面,然后因?yàn)槊恳恍卸加形鍌€(gè)數(shù)據(jù),所以我們就可以按照0~5一組的數(shù)據(jù)進(jìn)行分發(fā)給各處。
實(shí)際C++代碼如下:
vector<string> Parse_Wifi_List(string& msg)
{
vector<string> words;
if(msg.empty())
return words;
string::iterator temp_p = msg.begin();
string sepword;
bool bit_true = false;
while(temp_p != msg.end())
{
if(/* * temp_p == ' ' || */ * temp_p == '\t' || * temp_p == '\n')
{
if(bit_true)
{
words.push_back(sepword);
PP_INFO("seword :%s",sepword.c_str());
sepword.clear();
}
bit_true = false;
temp_p++;
continue;
}
else
{
bit_true = true;
sepword += *temp_p;
}
if(*temp_p ++ == '\0')
{
break;
}
// else
// {
// PP_INFO("%d %d %c",msg.end(),*temp_p,*temp_p);
// }
}
// for(auto point : words)
// {
// printf(".%s\n",point.c_str());
// }
//for(uint16_t i =0;i<words.size();i+=5)
//{
// printf("[]%s,%s\n",words[i].c_str(),words[i+1].c_str(),words[i+3].c_str());
//}
return words;
}
使用此代碼解析LOG如下:

結(jié)語(yǔ)
這就是我分享的一個(gè)簡(jiǎn)單的C++解析一些特殊符號(hào)的實(shí)踐,如果大家有更好的想法和需求,也歡迎大家加我好友交流分享哈。
到此這篇關(guān)于C++解析特殊符號(hào)tab、換行符號(hào)的文章就介紹到這了,更多相關(guān)C++解析特殊符號(hào)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語(yǔ)言鏈表實(shí)現(xiàn)商品庫(kù)存管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言鏈表實(shí)現(xiàn)商品庫(kù)存管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02
Qt實(shí)現(xiàn)邊加載數(shù)據(jù)邊顯示頁(yè)面的示例代碼
無論是MFC框架還是QT框架,實(shí)現(xiàn)加載數(shù)據(jù)的等待效果都是很麻煩的,不像WEB端輕輕松松一句代碼就搞定了。本文將通過Qt實(shí)現(xiàn)邊加載數(shù)據(jù)邊顯示頁(yè)面的功能,需要的可以參考一下2022-01-01
C++深入分析講解函數(shù)與重載知識(shí)點(diǎn)
C++?允許多個(gè)函數(shù)擁有相同的名字,只要它們的參數(shù)列表不同就可以,這就是函數(shù)的重載(Function?Overloading),借助重載,一個(gè)函數(shù)名可以有多種用途2022-06-06
簡(jiǎn)單掌握桶排序算法及C++版的代碼實(shí)現(xiàn)
桶排序是將要排序的算法按桶分組排序之后再遍歷匯總的一種線性排序算法,下面就讓我們來通過小例子簡(jiǎn)單掌握桶排序算法及C++版的代碼實(shí)現(xiàn)^^2016-07-07

