Linux 下sscanf用法

 

名称:

  sscanf() - 从一个字符串中读进与指定格式相符的数据.
 
  函数原型:
 
  int sscanf( const char *, const char *, ...);
 
  int sscanf(const char *buffer,const char *format,[argument ]...);
 
  buffer 存储的数据
 
  format 格式控制字符串
 
  argument 选择性设定字符串
 
  sscanf会从buffer里读进数据,依照argument的设定将数据写回。
 

头文件:

  #include<stdio.h>
 

返回值:

  成功则返回参数数目,失败则返回0,错误原因存于errno中。
 

说明:

  sscanf与scanf类似,都是用于输入的,只是后者以键盘(stdin)为输入源,前者以固定字符串为输入源。  
 
 第一个参数可以是一个或多个 {%[*] [width] [{h | l | I64 | L}]type | ' ' | '\t' | '\n' | 非%符号}
 
  注:
 
  1、 * 亦可用于格式中, (即 %*d 和 %*s) 加了星号 (*) 表示跳过此数据不读入. (也就是不把此数据读入参数中)
 
  2、{a|b|c}表示a,b,c中选一,[d],表示可以有d也可以没有d。
 
  3、width表示读取宽度。
 
  4、{h | l | I64 | L}:参数的size,通常h表示单字节size,I表示2字节 size,L表示4字节size(double例外),l64表示8字节size。
 
  5、type :这就很多了,就是%s,%d之类。
 
  6、特别的:%*[width] [{h | l | I64 | L}]type 表示满足该条件的被过滤掉,不会向目标参数中写入值
 
  失败返回0 ,否则返回格式化的参数个数
 

支持集合操作:

  %[a-z] 表示匹配a到z中任意字符,贪婪性(尽可能多的匹配)
 
  %[aB'] 匹配a、B、'中一员,贪婪性
 
  %[^a] 匹配非a的任意字符,并且停止读入,贪婪性
 
下面是一些测试代码:
 1 #include <stdio.h>
 2 #include <string.h>
 3 #include <stdlib.h>
 4 int main()
 5 {
 6     char str[512]="";
 7 
 8     //一、格式化输出字符串,相当于strcpy
 9     sscanf("123456", "%s", str);
10     puts(str);
11     /*output 123456*/
12     
13     
14     //二、取指定长度的字符串
15     strcpy(str, "");
16     sscanf("12345678", "%4s", str);
17     puts(str);
18     /*output 1234*/
19     
20     
21     //三、取到指定字符串为止。
22     sscanf("123456789 abcdfe", "%[^ ]", str);
23     puts(str);
24     /*output 123456789*/
25     
26     
27     //四、取仅包含指定字符集的字符串。如在下例中,取仅包含1到9和小写字母的字符串。
28     strcpy(str, "");
29     sscanf("89hkDFCCQQQQ", "%[1-9a-z]", str);   //123SFDAF89DFCC9QQQQsssssfdfa
30     puts(str);
31     /*output 89hk*/
32 
33     
34     //五、取到指定字符集为止的字符串。如在下例中,取遇到大写字母为止的字符串。
35     strcpy(str, "");
36     sscanf("123456789fdsafdsaDDDDDD", "%[^A-Z]", str);
37     puts(str);
38     /*output 123456789fdsafdsa*/
39     
40     
41     //六、取出下面字符串中数字2位为一组取出
42     char a1[3], a2[3], a3[3]; int i1,i2;
43     sscanf("12:34:56-7890", "%2s:%2s:%2s-%2d%2d", a1, a2, a3, &i1, &i2);
44     printf("--%s---%s----%s----%d----%d---\n", a1, a2, a3, i1, i2);
45     /*output 12 34 56 78 90*/
46 
47     
48     //七、以','为分割取出下面字符串
49     char a4[10], a5[10], a6[10], a7[10]; 
50     sscanf("first,25.5,second,15", "%5s,%4s,%6s,%2s", a4, a5, a6, a7);     /*method one*/
51     sscanf("first,25.5,second,15", "%[^,],%[^,],%[^,],%s", a4, a5, a6, a7);/*method two*/
52     printf("--%s---%lf----%s----%d--\n", a4, atof(a5), a6, atoi(a7));
53     /*output first 25.500000 seond 15*/
54     
55     
56     //八、给定一个字符串iios/12DDWDFF@122,获取 '/' 和 '@' 之间的字符串,
57     //先将 "iios/"过滤掉,再将非'@'的一串内容送到buf中   
58     strcpy(str, "");
59     sscanf("iios/12DDWDFF@122", "%*[^/]/%[^@]", str);
60     puts(str);
61     /*ouput: 12DDWDFF*/
62     
63     
64     //九、给定一个字符串"hello, world",仅保留world。
65     //(注意:","之后有一空格,%s遇空格停止,加*则是忽略第一个读到的字符串)
66     strcpy(str, "");
67     sscanf("hello, world", "%*s%s", str);
68     puts(str);
69     /*output: wrold*/
70     
71     
72     //十、处理时间分割函数
73     char a8[15], a9[15];
74     //sscanf("2006:03:18 - 2006:04:18", "%s - %s", a8, a9);
75     //sscanf("2006:03:18-2006:04:18", "%s-%s", a8, a9);     //error
76     sscanf("2006:03:18-2006:04:18", "%[^-]-%s", a8, a9);    //method one
77     sscanf("2006:03:18-2006:04:18", "%10s-%10s", a8, a9);   //method two
78     printf("#######%s#########%s######\n", a8, a9);
79     /*output: 2006:03:18 2006:04:18*/
80 
81     
82     //十一、指定要跳过的字符串
83     char a10[15], a11[15]; 
84     sscanf("iosVSandroid", "%[a-z]VS%[a-z]", a10, a11);
85     printf("###%s######%s###\n", a10, a11);
86     /*output: ios android*/
87     
88     
89     //十二、提取邮箱地址
90     char a12[10], a13[10], a14[10], a15[10];
91     sscanf("Email:beijing@sina.com.cn", "%[^:]:%[^@]@%[^.].%s", a12, a13, a14, a15);
92     printf("#####%s#######%s#######%s######%s####\n", a12, a13, a14, a15);
93     /*output: Email  beijing  sina   com.cn*/
94     return 0;
95 }

 

 
 
 
posted @ 2012-11-14 18:31  24K.纯帅  阅读(1499)  评论(0编辑  收藏  举报