sscanf用法

sscanf的用法 #include int main() { const char* s = "iios/12DDWDFF@122"; 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:宽度,一般可以忽略,用法如: 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 表示满足该条件的被过滤掉,不会向目标参数中写入值。如: 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的任意字符,贪婪性 是不是感觉眼熟了啊,不错,这和正则表达式很相似,而且仍然支持过滤,即可以有%*[a-z].如: const char* s = "iios/12DDWDFF@122"; char buf[20]; sscanf( s, "%*[^/]/%[^@]", buf ); printf( "%s/n", buf ); 先将 "iios/"过滤掉,再将非'@'的一串内容送到buf中,cool.得到结果。 另: scanf/sscanf 函数的返回值反映的是按照指定的格式符正确读入的数据的个数。如果输入数据与指定格式不符,则会产生输入错误。遇到输入错误,scanf函数会立即终止,返回已经成功读取的数据的个数。所以,通过scanf函数的返回值和指定输入数据的个数(由格式符决定)的比较,可以判断数据输入是否成功。 大家都知道sscanf是一个很好用的函数,利用它可以从字符串中取出整数、浮点数和字符串等等。它的使用方法简单,特别对于整数和浮点数来说。但新手可能并不知道处理字符串时的一些高级用法,这里做个简要说明吧。   1. 常见用法。 以下是引用片段: charstr[512]={0}; sscanf("123456","%s",str); printf("str=%s ",str);   2. 取指定长度的字符串。如在下例中,取最大长度为4字节的字符串。 以下是引用片段: sscanf("123456","%4s",str); printf("str=%s ",str);   3. 取到指定字符为止的字符串。如在下例中,取遇到空格为止字符串。 以下是引用片段: sscanf("123456abcdedf","%[^]",str); printf("str=%s ",str);   4. 取仅包含指定字符集的字符串。如在下例中,取仅包含1到9和小写字母的字符串。 以下是引用片段: sscanf("123456abcdedfBCDEF","%[1-9a-z]",str); printf("str=%s ",str);   5. 取到指定字符集为止的字符串。如在下例中,取遇到大写字母为止的字符串。 以下是引用片段: sscanf("123456abcdedfBCDEF","%[^A-Z]",str); printf("str=%s",str); 摘自:http://nbjk1986.blog.163.com/blog/static/16360379320104653540679/

你可能感兴趣的:(c,正则表达式,360,2010)