Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1345160
  • 博文数量: 244
  • 博客积分: 10311
  • 博客等级: 上将
  • 技术积分: 3341
  • 用 户 组: 普通用户
  • 注册时间: 2008-10-14 21:50
文章分类

全部博文(244)

文章存档

2013年(6)

2012年(5)

2011年(16)

2010年(11)

2009年(172)

2008年(34)

分类: LINUX

2011-07-06 13:34:39

sscanf基本用法
 
sscanf(Version,"%d.%d.%d.%d",&bySelfFirst,&bySelfSecond,&bySelfThird,   &bySelfFourth);

//从字符串中读特定字符。
Version是用来作输入的,   它里面有四个整数,分别赋值给后面四个数

sscanf和sprintf是scanf和printf家族的一对成员,用于处理和分析字符串非常强大得两个函数
头文件 stdio.h
原型
int sscanf(
           const char *buffer,
           const char *format,
           ...
           );
int sprintf(
                  char *buffer,
            const char *format,
           ...
           );
功能:类似于scanf和printf 但从字符串*buffer用于输入输出
1.sprintf用于格式化字符串
把变量打印到字符串中,从而获得数字的字符形式,这样不需要手工转换。
例如
 char c[100];
 int k=255;
 sprintf(c,"%d",k);
//c包含"255"
2.sprintf用于进制转换
可以方便地得到变量的十六进制和八进制字符序列,再稍加处理即可得到每一位的值。
 char c[100];
 int k=255;
 sprintf(c,"%x",k);
//c包含"ff" c[0]='f' c[1]='f'
3.sprintf用于连接字符串
方便地连接两个或者多个字符串
 char buf[1024];
 char a[100]="I ";
 char b[100]="love ";
 char c[100]="ACM."
 sprintf(buf,"%s%s%s",a,b,c);
 //buf 包含"I love ACM."
4.sscanf用于处理输入
有些比较麻烦的输入输出用sscanf处理将会非常方便
如hrbeu1002 (这里给出的不是完整代码,其中输出部分只是简单地原样打印出来。)
因为scanf在使用除了%c以外的格式时都忽略换行符'/n',题中用空行来区分不同case的要求
显得难以处理,如果使用sscanf的话,可以先把输入用scanf存入一块缓冲区当中,再用sscanf读取
这样大大减少了工作量。
#include
int T[100];
int P[100];
int i;
bool Input()
{
 int p=0;
 char buf[1024];
 i=0;
 while(scanf("%c",&buf[p])!=EOF)
 {
    if(buf[p]==10)
    {
       if(p==0)return 1;
       sscanf(buf,"%d %d",&T[i],&P[i]);
       i++;
       p=-1;
    }
    p++;
 }
 return 0;
}
void output()
{
    int j;
    for(j=0;j    {
       printf("%d %d/n",T[j],P[j]);
    }
    printf("/n");
}

int main()
{
   while(Input())output();
   return 0;
}
 
sscanf用于分析字符串
sscanf可以支持格式字符%[] 这为分析字符串提供了很大方便(其实scanf也支持%[])
先看一下%[] 格式:
(1)-: 表示范围,如:%[1-9]表示只读取1-9这几个数字 %[a-z]表示只读取a-z小写字母,类似地 %[A-Z]只读取大写字母
(2)^: 表示不取,如:%[^1]表示读取除'1'以外的所有字符 %[^/]表示除/以外的所有字符
(3),: 范围可以用","相连接 如%[1-9,a-z]表示同时取1-9数字和a-z小写字母
(4)原则:从第一个在指定范围内的数字开始读取,到第一个不在范围内的数字结束%s 可以看成%[] 的一个特例 %[^ ](注意^后面有一个空格!)
这样使用sscanf+%[]可以轻松的分析字符串,很多字符串问题便迎刃而解了。
以hrbeu3001为例(不是完整代码,没有要求的格式)
只需2个sscanf函数,就能完成题目的要求,代码非常简洁。
#include
#include
int main(int argc, char *argv[])
{
  char buf[1024],str1[100],str2[100],str3[100],str4[100],temp[100]="";
 
  int count;
  scanf("%d",&count);
  while(count--)
  {
     str1[0]='/0';
     str2[0]='/0';
     str3[0]='/0';
     str4[0]='/0';
     scanf("%s",buf);
     sscanf(buf,"%[^:]://%[^:,/]:%[,1-9]",str1,str2,str3,str4);
     sscanf(buf,"%[^:]://%[^:,/]/%[a-z,A-Z,/,~]",str1,str2,str4);
     if(str3[0]=='/0')strcpy(str3,temp);
     if(str4[0]=='/0')strcpy(str4,temp);
     printf("%s/n%s/n%s/n%s/n",str1,str2,str3,str4);
  }
  return 0;
 
#######################################################################
int main()
{
  char str[]="\"7754321\"\r\n";
  char buf[50];
  memset(buf,'\0',sizeof(buf));
  sscanf(&(str[0]),"\"%s\"",buf);
  printf("str=[%s],buf=[%s]\n",str,buf);
}
输出结果:
str=["7754321"
],buf=[7754321"]

解决办法是:
 
int main()
{
  char str[]="\"7754321\"\r\n";
  char buf[50];
  memset(buf,'\0',sizeof(buf));
  sscanf(&(str[0]),"\"%[^\"]s\"",buf);
  printf("str=[%s],buf=[%s]\n",str,buf);
}
 
 
阅读(4214) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~