Linux C语言中sscanf 的详细用法

2024-04-12 03:18

本文主要是介绍Linux C语言中sscanf 的详细用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

sscanf() - 从一个字符串中读进与指定格式相符的数据.
[cpp] view plaincopyprint?
  1. 函数原型:  
  2.   
  3. Int  sscanf( string str, string fmt, mixed var1, mixed var2 ... );  
  4.   
  5. int scanf( const char *format [,argument]... );  

说明:

sscanf与scanf类似,都是用于输入的,只是后者以屏幕(stdin)为输入源,前者以固定字符串为输入源。
其中的format可以是一个或多个 {%[*] [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 表示满足该条件的被过滤掉,不会向目标参数中写入值 

支持集合操作:

     %[a-z] 表示匹配a到z中任意字符,贪婪性(尽可能多的匹配)

     %[aB'] 匹配a、B、'中一员,贪婪性

     %[^a] 匹配非a的任意字符,贪婪性


下面是一段实例程序

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

这篇关于Linux C语言中sscanf 的详细用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/895957

相关文章

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

在Linux中改变echo输出颜色的实现方法

《在Linux中改变echo输出颜色的实现方法》在Linux系统的命令行环境下,为了使输出信息更加清晰、突出,便于用户快速识别和区分不同类型的信息,常常需要改变echo命令的输出颜色,所以本文给大家介... 目python录在linux中改变echo输出颜色的方法技术背景实现步骤使用ANSI转义码使用tpu

linux hostname设置全过程

《linuxhostname设置全过程》:本文主要介绍linuxhostname设置全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录查询hostname设置步骤其它相关点hostid/etc/hostsEDChina编程A工具license破解注意事项总结以RHE

Go语言中make和new的区别及说明

《Go语言中make和new的区别及说明》:本文主要介绍Go语言中make和new的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1 概述2 new 函数2.1 功能2.2 语法2.3 初始化案例3 make 函数3.1 功能3.2 语法3.3 初始化

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

解读GC日志中的各项指标用法

《解读GC日志中的各项指标用法》:本文主要介绍GC日志中的各项指标用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、基础 GC 日志格式(以 G1 为例)1. Minor GC 日志2. Full GC 日志二、关键指标解析1. GC 类型与触发原因2. 堆

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码