scanf, sscanf 函数用法

本文详细介绍了sscanf函数的使用方法及实例,包括如何从字符串中读取特定格式的数据,支持的格式符及其特殊用途,例如跳过数据或指定读取长度。

名称:

sscanf() - 从一个字符串中读进与指定格式相符的数据.

 

函数原型:

Int  sscanf( string str, string fmt, mixed var1, mixed var2 ... );

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的任意字符,贪婪性

 

 

 

例子:

 

1. 常见用法。

    char buf[512] = {0};

    sscanf("123456 ""%s"buf);

printf("%s\n"buf);

 

结果为:123456

 

 

2. 取指定长度的字符串。如在下例中,取最大长度为4字节的字符串。

    sscanf("123456 ""%4s"buf);

printf("%s\n"buf);

 

结果为:1234

 

 

3. 取到指定字符为止的字符串。如在下例中,取遇到空格为止字符串。

    sscanf("123456 abcdedf""%[^ ]"buf);

printf("%s\n"buf);

 

结果为:123456

 

 

4.  取仅包含指定字符集的字符串。如在下例中,取仅包含1到9和小写字母的字符串。

    sscanf("123456abcdedfBCDEF""%[1-9a-z]"buf);

printf("%s\n"buf);

 

结果为:123456abcdedf

 

 

5.  取到指定字符集为止的字符串。如在下例中,取遇到大写字母为止的字符串。

    sscanf("123456abcdedfBCDEF""%[^A-Z]"buf);

printf("%s\n"buf);

 

结果为:123456abcdedf

 

 

  

6、给定一个字符串iios/12DDWDFF@122获取 /  @ 之间的字符串,先将 "iios/"过滤掉,再将非'@'的一串内容送到buf

sscanf("iios/12DDWDFF@122""%*[^/]/%[^@]"buf);

printf("%s\n"buf);

 

结果为:12DDWDFF

 

 

7、给定一个字符串““hello, world”,仅保留world。(注意:“,”之后有一空格)

sscanf(“hello, world”,  "%*s%s",  buf);  

printf("%s\n"buf);

 

 

结果为:world

 

%*s表示第一个匹配到的%s被过滤掉,即hello被过滤了

 

如果没有空格则结果为NULL



sscanf的功能很类似于正则表达式, 但却没有正则表达式强大,所以如果对于比较复杂的字符串处理,建议使用正则表达式.

 

独立储能的现货电能量调频辅助服务市场出清协调机制(Matlab代码实现)内容概要:本文围绕“独立储能的现货电能量调频辅助服务市场出清协调机制”展开,提出了一种基于Matlab代码实现的优化模型,旨在协调独立储能系统在电力现货市场调频辅助服务市场中的联合出清问题。文中结合鲁棒优化、大M法和C&CG算法处理不确定性因素,构建了多市场耦合的双层或两阶段优化框架,实现了储能资源在能量市场和辅助服务市场间的最优分配。研究涵盖了市场出清机制设计、储能运行策略建模、不确定性建模及求解算法实现,并通过Matlab仿真验证了所提方法的有效性和经济性。; 适合人群:具备一定电力系统基础知识和Matlab编程能力的研究生、科研人员及从事电力市场、储能调度相关工作的工程技术人员。; 使用场景及目标:①用于研究独立储能在多电力市场环境下的协同优化运行机制;②支撑电力市场机制设计、储能参市场的竞价策略分析及政策仿真;③为学术论文复现、课题研究和技术开发提供可运行的代码参考。; 阅读建议:建议读者结合文档中提供的Matlab代码算法原理同步学习,重点关注模型构建逻辑、不确定性处理方式及C&CG算法的具体实现步骤,宜在掌握基础优化理论的前提下进行深入研读仿真调试。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值