1. 常見用法
[cpp] view plain copy print?
- sscanf("123456 ", "%s", str);
2. 取指定長度的字符串。如在下例中,取最大長度爲4字節的字符串。
[cpp] view plain copy print?
- sscanf("123456 ", "%4s", str);
3. 取到指定字符爲止的字符串。如在下例中,取遇到空格爲止字符串。
[cpp] view plain copy print?
- sscanf("123456 abcdedf", "%[^ ]", str);
4. 取僅包含指定字符集的字符串。如在下例中,取僅包含1到9和小寫字母的字符串。
[cpp] view plain copy print?
- sscanf("123456abcdedfBCDEF", "%[1-9a-z]", str);
5. 取到指定字符集爲止的字符串。如在下例中,取遇到大寫字母爲止的字符串。
[cpp] view plain copy print?
- sscanf("123456abcdedfBCDEF", "%[^A-Z]", str);
6. 用它來分隔類似這樣的字符串2006:03:18:
[cpp] view plain copy print?
- int a, b, c;
- sscanf("2006:03:18", "%d:%d:%d", &a, &b, &c);
以及2006:03:18 - 2006:04:18:
[cpp] view plain copy print?
- char sztime1[16] = "", sztime2[16] = "";
- sscanf("2006:03:18 - 2006:04:18", "%s - %s", sztime1, sztime2);
7. 原問題:iios/12DDWDFF@122 獲取/和@之間的字符串怎麼做
[cpp] view plain copy print?
- #include <stdio.h>
- int main()
- {
- const char* s = "<span style="word-wrap: normal; word-break: normal;">iios/12DDWDFF@122</span>";
- char buf[20];
- sscanf( s, "%*[^/]/%[^@]", buf );
- printf( "%s\n", buf );
- return 0;
- }
結果爲:12DDWDFF
sscanf與scanf類似,都是用於輸入的,只是後者以屏幕(stdin)爲輸入源,前者以固定字符串爲輸入
源。
函數原型:
int scanf( const char *format [,argument]... );
其中的format可以是一個或多個 {%[*] [width] [{h | l | I64 | L}]type |' '|'\t'|'\n'|非%符
號}
注:{a|b|c}表示a,b,c中選一,[d],表示可以有d也可以沒有d。
width:寬度,一般可以忽略
用法如:
[cpp] view plain copy print?
- const char sourceStr[] = "hello, world";
- char buf[10] = {0};
- sscanf(sourceStr, "%5s", buf); //%5s,只取5個字符
- cout << buf<< endl;
結果爲:hello
{h | l | I64 | L}:參數的size,通常h表示單字節size,I表示2字節size,L表示4字節size(double例
外),l64表示8字節size。
type: 這就很多了,就是%s,%d之類。
特別的:
%*[width] [{h | l | I64 | L}]type 表示滿足該條件的被過濾掉,不會向目標參數中寫入值。如:
[cpp] view plain copy print?
- const char sourceStr[] = "hello, world";
- char buf[10] = {0};
- sscanf(sourceStr, "%*s%s", buf); //%*s表示第一個匹配到的%s被過濾掉,即hello被過濾了
- cout << buf<< endl;
結果爲:world
支持集合操作:
%[a-z] 表示匹配a到z中任意字符,貪婪性(儘可能多的匹配)
%[aB'] 匹配a、B、'中一員,貪婪性
%[^a] 匹配非a的任意字符,貪婪性
sscanf可以支持格式字符%[] 這爲分析字符串提供了很大方便(其實scanf也支持%[])
先看一下%[] 格式:
(1)-: 表示範圍,如:%[1-9]表示只讀取1-9這幾個數字 %[a-z]表示只讀取a-z小寫字母,類似地 %
[A-Z]只讀取大寫字母
(2)^: 表示不取,如:%[^1]表示讀取除'1'以外的所有字符 %[^/]表示除/以外的所有字符
(3),: 範圍可以用","相連接 如%[1-9,a-z]表示同時取1-9數字和a-z小寫字母
(4)原則:從第一個在指定範圍內的數字開始讀取,到第一個不在範圍內的數字結束%s 可以看成%[]
的一個特例 %[^ ](注意^後面有一個空格!)
這和正則表達式很相似,而且仍然支持過濾,即可以有%*[a-z].如:
[cpp] view plain copy print?
- const char* s = "";
- char buf[20];
- sscanf( s, "%*[^/]/%[^@]", buf );
- printf( "%s\n", buf );
先將 "iios/"過濾掉,再將非的一串內容送到buf中,cool.得到結果。
例:
[cpp] view plain copy print?
- sscanf("wpc:123456", "%127[^:]:%127[^ ]", user_name, password);
結果:user_name是wpc,password是123456
[cpp] view plain copy print?
- sscanf( "" , "%*[^/]/%d[^D]", &i );
結果:12342
[cpp] view plain copy print?
- string szMsg("0001A");
- unsigned long ulValue = 0;
- sscanf(szMsg.c_str(), "%4x", &ulValue);
結果:1
[cpp] view plain copy print?
- string szMsg("0001A");
- unsigned long ulValue = 0;
- sscanf(szMsg.c_str(), "%x", &ulValue);
結果:26
[cpp] view plain copy print?
- string szMsg
- ("_Community=public&_MachineName=192.168.6.96&_Port=161&devicetype=_SnmpWin&seid=2");
- char *pPos = strstr(szMsg.c_str(), "devicetype=");
- if(pPos)
- {
- char *chDevID = new char[strlen(pPos)];
- if(chDevID)
- {
- memset(chDevID, 0, strlen(pPos));
- cout << pPos << endl;
- sscanf(pPos, "devicetype= %[^&]", chDevID);
- cout << "Device Type is:" << chDevID << endl;
- delete []chDevID;
- }
- }
結果:
devicetype=_SnmpWin&seid=2
Device Type is:_SnmpWin
sscanf(格式化字符串輸入)
相關函數 |
scanf,fscanf |
表頭文件 |
#include<stdio.h> |
定義函數 |
int sscanf (const char *str,const char * format,........); |
函數說明 |
sscanf()會將參數str的字符串根據參數format字符串來轉換並格式化數據。格式轉換形式請參考scanf()。轉換後的結果存於對應的參數內。 |
返回值 |
成功則返回參數數目,失敗則返回-1,錯誤原因存於errno中。 |
範例 |
#include<stdio.h> main() { int i; unsigned int j; char input[ ]=”10 0x1b aaaaaaaa bbbbbbbb”; char s[5]; sscanf(input,”%d %x %5[a-z] %*s %f”,&i,&j,s,s); printf(“%d %d %s\n”,i,j,s); } |
執行 |
10 27 aaaaa |
CString szNetworkP = "0|192.168.1.101|192.168.1.1|255.255.255.0|192.168.1.1|554|80";
char strDhcpFlag[100];
char strIp[100];
char strGateway[100];
char strMask[100];
char strDNS[100];
char strRtspPort[100];
char strOnvifPort[100];
//sscanf(szNetworkP, "%[^|]|%[^|]|%[^|]|%[^|]|%[^|]|%[^|]|%[^|]", &strDhcpFlag, &strIp, &strGateway, &strMask, &strDNS, &strRtspPort, &strOnvifPort);
sscanf(szNetworkP, "%[^|]|%[^|]|%[^|]|%[^|]|%[^|]|%[^|]|%[^|]", strDhcpFlag, strIp, strGateway, strMask, strDNS, strRtspPort, strOnvifPort);
CString sztime1, sztime2;
//sscanf("2006:03:18 2006:04:18", "%s %s", sztime1, sztime2);
//sscanf("2006:03:18 - 2006:04:18", "%s - %s", sztime1, sztime2);
CString buf1;
sscanf("123456 abcdedf", "%[^ ]", buf1);
//printf("%s\n", buf);
char buf[]="port=5000";
char key[100]="";
char value[100]="";
//sscanf(buf,"%[^=]=%[^\n]",key,value);
sscanf(buf,"%[^=]=%s",key,value);