前言:
我們經常會遇到一些Linux內核信息需要,比如一個wifi數據,中間是用tab鍵盤隔開的,然后每一行用換行符進行區分,如下所示的數據
第一位置是:wifi名稱 第二個位置是:信號強度 第三個位置是:信號類型2.4Ghz或者5Ghz 第四個位置是:加密類型 第五個類型是:MAC地址
遇到這樣的數據,我們比較常見的C函數解析是用while循環去匹配字符串里面的'\t'(tab鍵),'\n'(換行符號)等,然后用C標準庫里面str函數,例如strncpy進行復制或者strstr去查找,類似于下面所示:
1
2
3
4
5
6
7
8
9
|
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信息,所以給大家分享哈這部分。
解析代碼
對應上面的wifi信息的表,我們看到了一行有五個數據,這時候打包收到了一個string類型的wifi信息。
第一件事情,我們先確認好解析的范圍,即知道最開始一位和最后一位,設置好recivemsg.begin 和 recivemsg.
第二件事情,進行識別tab符號和換行符號之后進行分段
第三件事情,把分好的數據塞到一個vector容器里面,然后因為每一行都有五個數據,所以我們就可以按照0~5一組的數據進行分發給各處。
實際C++代碼如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
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如下:
結語
這就是我分享的一個簡單的C++解析一些特殊符號的實踐,如果大家有更好的想法和需求,也歡迎大家加我好友交流分享哈。
到此這篇關于C++解析特殊符號tab、換行符號的文章就介紹到這了,更多相關C++解析特殊符號內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!
原文鏈接:https://mp.weixin.qq.com/s/NCaY9okJQYLBGB56viLr4A