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", "7[^:]:7[^ ]", 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 aaaaaCString 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);