sscanf使用详解

				版权声明:本文为博主原创文章,未经博主允许不得转载。					https://blog.csdn.net/gzshun/article/details/7081736				</div>
							<link rel="stylesheet" href="https://csdnimg.cn/release/phoenix/template/css/ck_htmledit_views-f57960eb32.css">
							            <link rel="stylesheet" href="https://csdnimg.cn/release/phoenix/template/css/ck_htmledit_views-f57960eb32.css">
					<div class="htmledit_views" id="content_views">

在处理字符串的程序当中,经常会分析字符串,从一大长串的字符串截取我们需要的数据,这如果通过自己手写函数来分析,虽然可以,但当你知道sscanf的功能,那就自己写函数分析就显得多此一举。

这些函数的使用都很简单,总结一下,等下次使用一目了然。俗话说:好记性不如烂笔头,记录下来就是效率。

以下源代码是本人测试的源文件,附带讲解注释。



 
 
  1. /*****************************************************
  2. ** Name : sscanf.c
  3. ** Author : gzshun
  4. ** Version : 1.0
  5. ** Date : 2011-12
  6. ** Description : sscanf function
  7. ******************************************************/
  8. #include <stdio.h>
  9. #include <stdlib.h>
  10. #include <string.h>
  11. static void sscanf_test(void);
  12. static void sscanf_test(void)
  13. {
  14. int ret;
  15. char * string;
  16. int digit;
  17. char buf1[ 255];
  18. char buf2[ 255];
  19. char buf3[ 255];
  20. char buf4[ 255];
  21. /*1.最简单的用法*/
  22. string = "china beijing 123";
  23. ret = sscanf( string, "%s %s %d", buf1, buf2, &digit);
  24. printf( "1.string=%s\n", string);
  25. printf( "1.ret=%d, buf1=%s, buf2=%s, digit=%d\n\n", ret, buf1, buf2, digit);
  26. /*
  27. **执行结果:
  28. **1.ret=3, buf1=china, buf2=beijing, digit=123
  29. **可以看出,sscanf的返回值是读取的参数个数
  30. */
  31. /*2.取指定长度的字符串*/
  32. string = "123456789";
  33. sscanf( string, "%5s", buf1);
  34. printf( "2.string=%s\n", string);
  35. printf( "2.buf1=%s\n\n", buf1);
  36. /*
  37. **执行结果:
  38. **2.buf1=12345
  39. */
  40. /*3.取到指定字符为止的字符串*/
  41. string = "123/456";
  42. sscanf( string, "%[^/]", buf1);
  43. printf( "3.string=%s\n", string);
  44. printf( "3.buf1=%s\n\n", buf1);
  45. /*
  46. **执行结果:
  47. **3.buf1=123
  48. */
  49. /*4.取到指定字符集为止的字符串*/
  50. string = "123abcABC";
  51. sscanf( string, "%[^A-Z]", buf1);
  52. printf( "4.string=%s\n", string);
  53. printf( "4.buf1=%s\n\n", buf1);
  54. /*
  55. **执行结果:
  56. **4.buf1=123abc
  57. */
  58. /*5.取仅包含指定字符集的字符串*/
  59. string = "0123abcABC";
  60. sscanf( string, "%[0-9]%[a-z]%[A-Z]", buf1, buf2, buf3);
  61. printf( "5.string=%s\n", string);
  62. printf( "5.buf1=%s, buf2=%s, buf3=%s\n\n", buf1, buf2, buf3);
  63. /*
  64. **执行结果:
  65. **5.buf1=123, buf2=abc, buf3=ABC
  66. */
  67. /*6.获取指定字符中间的字符串*/
  68. string = "ios<android>wp7";
  69. sscanf( string, "%*[^<]<%[^>]", buf1);
  70. printf( "6.string=%s\n", string);
  71. printf( "6.buf1=%s\n\n", buf1);
  72. /*
  73. **执行结果:
  74. **6.buf1=android
  75. */
  76. /*7.指定要跳过的字符串*/
  77. string = "iosVSandroid";
  78. sscanf( string, "%[a-z]VS%[a-z]", buf1, buf2);
  79. printf( "7.string=%s\n", string);
  80. printf( "7.buf1=%s, buf2=%s\n\n", buf1, buf2);
  81. /*
  82. **执行结果:
  83. **7.buf1=ios, buf2=android
  84. */
  85. /*8.分割以某字符隔开的字符串*/
  86. string = "android-iphone-wp7";
  87. /*
  88. **字符串取道'-'为止,后面还需要跟着分隔符'-',
  89. **起到过滤作用,有点类似于第7点
  90. */
  91. sscanf( string, "%[^-]-%[^-]-%[^-]", buf1, buf2, buf3);
  92. printf( "8.string=%s\n", string);
  93. printf( "8.buf1=%s, buf2=%s, buf3=%s\n\n", buf1, buf2, buf3);
  94. /*
  95. **执行结果:
  96. **8.buf1=android, buf2=iphone, buf3=wp7
  97. */
  98. /*9.提取邮箱地址*/
  99. string = "Email:beijing@sina.com.cn";
  100. sscanf( string, "%[^:]:%[^@]@%[^.].%s", buf1, buf2, buf3, buf4);
  101. printf( "9.string=%s\n", string);
  102. printf( "9.buf1=%s, buf2=%s, buf3=%s, buf4=%s\n\n", buf1, buf2, buf3, buf4);
  103. /*
  104. **执行结果:
  105. **9.buf1=Email, buf2=beijing, buf3=sina, buf4=com.cn
  106. */
  107. /*10.过滤掉不想截取或不需要的字符串--补充,
  108. **在%号后面加一*号,代表过滤这个字符串,不读取
  109. */
  110. string = "android iphone wp7";
  111. sscanf( string, "%s %*s %s", buf1, buf2);
  112. printf( "10.string=%s\n", string);
  113. printf( "10.buf1=%s, buf2=%s\n\n", buf1, buf2);
  114. /*
  115. **执行结果:
  116. **10.android wp7
  117. */
  118. }
  119. int main(int argc, char **argv)
  120. {
  121. sscanf_test();
  122. return 0;
  123. }
  124. /*
  125. **测试程序
  126. **环境:
  127. **Linux ubuntu 2.6.32-24-generic-pae #39-Ubuntu SMP Wed Jul 28 07:39:26 UTC 2010 i686 GNU/Linux
  128. **gcc version 4.4.3 (Ubuntu 4.4.3-4ubuntu5)
  129. **
  130. gzshun@ubuntu:~/c/sscanf$ gcc sscanf.c -o sscanf
  131. gzshun@ubuntu:~/c/sscanf$ ./sscanf
  132. 1.string=china beijing 123
  133. 1.ret=3, buf1=china, buf2=beijing, digit=123
  134. 2.string=123456789
  135. 2.buf1=12345
  136. 3.string=123/456
  137. 3.buf1=123
  138. 4.string=123abcABC
  139. 4.buf1=123abc
  140. 5.string=0123abcABC
  141. 5.buf1=0123, buf2=abc, buf3=ABC
  142. 6.string=ios<android>wp7
  143. 6.buf1=android
  144. 7.string=iosVSandroid
  145. 7.buf1=ios, buf2=android
  146. 8.string=android-iphone-wp7
  147. 8.buf1=android, buf2=iphone, buf3=wp7
  148. 9.string=Email:beijing@sina.com.cn
  149. 9.buf1=Email, buf2=beijing, buf3=sina, buf4=com.cn
  150. 10.string=android iphone wp7
  151. 10.buf1=android, buf2=wp7
  152. */



                
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值