sscanf用法

提示:最重要的是第二个参数与第一个参数要完全一致,如例二中遇到#结束但是后面又紧跟了一个#,这样第二个参数的形式和第一个才完全一样!!

 

 

相关函数 scanffscanf

表头文件: #include <stdio.h>

定义函数: int sscanf (const char *str, const char * format,........);

函数说明:sscanf()会将参数str的字符串根据参数format字符串来转换并格式化数据。格式转换形式请参考scanf()。转换后的结果存于对应的参数内。

返回值 :成功则返回参数数目,失败则返回-1,错误原因存于errno中。 返回0表示失 否则,表示正确格式化数据的个数 例如:sscanf(str"%d%d%s", &i,&i2, &s); 如果三个变量都读入成功会返回3 如果只读入了第一个整数到i则会返回1。证明无法从str读入第二个整数。 

例子:

#include<stdio.h>

main()

{

int i;

unsigned int j;

char input[ ]="10 0x1b aaaaaaaa bbbbbbbb";

char s[5];

sscanf(input,"%d %x %5[a-z] %*s %f",&i,&j,s,s);

printf("%d %d %s\n",i,j,s);

}

 例二:

#include<stdio.h>

main()

{

int i;

unsigned int j;

char input[ ]="abcdefghij#0123456789#abcdefghij 0123456789#";

char s1[40];
char s2[40];
sscanf(input, "%20[^#]#%20[^ ]",s1,s2);
printf("%s\n%s\n",s1,s2);

}

 sscanf(stringBuf.c_str(), "%20[^#]#%20[^ ]",......)语句中""中的内容含义为:

“%[]”符号用于声明字符串,它比“%s”更具体,可以用于设置读取的样式。例如“%[a-z]”

只读取小写字母,读到其它字符就结束。注意,方括号中如果有“^”,代表一直读到某字符为止。

例如:

“%[^#]”:读取字符串,一直到出现号为止(不包括)。

“%20[^#]”:读取20个字节的字符串,出现号时结束。

所以,“%20[^#]#%20[^ ]”的意义就是,

读取两个字符串(最多读入20个字符),第一个字符串可以用#结束,第二个字符串可以用回车符结束。

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

以下是引用片段:

  sscanf("123456","%4s",str);

        printf("str=%s\n",str);

        str=123456

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

以下是引用片段:

  sscanf("123456abc dedf","%[^ ]",str);
       printf("str=%s\n",str);

      str=123456abc

  取仅包含指定字符集的字符串。如在下例中,取仅包含19和小写字母的字符串。

以下是引用片段:

         sscanf("123456abcdedfBabck","%[1-9a-z]",str);
         printf("str=%s\n",str);

        str=123456abcdedf

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

以下是引用片段:

  sscanf("123456abcdedfBCDEF","%[^A-Z]",str);
       printf("str=%s\n",str);

      str=123456abcdedf

 

以前曾经编写过这样的小程序:一个文本文件,每行是一条记录,每条记录中包含多个字段,每个字段之间以某种定界符分开,举例如下:

Notebook#ThinkPad# 12000#6#X32#IBM

(各字段以逗号分隔,内容依次是:物品名称,生产厂家,型号,数量,价格)

如果要对这样的一行记录进行处理,提取出各个字段,怎么做比较好呢?

我以前的做法是在一个循环中用strtok函数每次取一个字段,然后将内容保存到一个字符串数组中。这样做虽然可行,但我总感觉写出的代码有些啰嗦。

最近看到一段代码,用C的标准库函数sscanf,处理这样的数据,只需一行就可以了。我把代码整理了一下,去掉了无关的部分,核心部分如下:

#include<stdio.h>
#include<iostream>
using namespace std;
main()

{

float price;

int quantity;

char category[21], name[21];

char vendor[21], sku[21];

char buf[201];

FILE *fp = fopen("f://1.txt", "r");

fgets(buf, 200, fp);

sscanf(buf,"%20[^#]#%20[^#]#%f#%i#%20[^#]#%20[^/n]",name, sku, &price, &quantity, category, vendor);
cout<<name<<"\n"<<sku<<"\n"<<price<<"\n"<<quantity<<"\n"<<category<<"\n"<<vendor<<"\n";

 

}

 

 

下面简单做些解说:

%20[^#]# 最多读入20个字符,直到遇见定界符#,但不包含定界符

%f# 读入一个浮点数,直到遇见定界符#

%i# 读入一个整数,直到遇见定界符#

%20[^\n] 最多读入20个字符,忽略行尾的回车符

是不是很简洁明了呢?

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值