欢迎来到入门教程网!

C语言

当前位置:主页 > 软件编程 > C语言 >

详解C语言sscanf()函数、vsscanf()函数、vscanf()函数

来源:本站原创|时间:2020-01-10|栏目:C语言|点击:

C语言sscanf()函数:从字符串中读取指定格式的数据
头文件:

#include <stdio.h>

sscanf()函数用于从字符串中读取指定格式的数据,其原型如下:
   

 int sscanf (char *str, char * format [, argument, ...]);

【参数】参数str为要读取数据的字符串;format为用户指定的格式;argument为变量,用来保存读取到的数据。

【返回值】成功则返回参数数目,失败则返回-1,错误原因存于errno 中。

sscanf()会将参数str 的字符串根据参数format(格式化字符串)来转换并格式化数据(格式化字符串请参考scanf()), 转换后的结果存于对应的变量中。

sscanf()与scanf()类似,都是用于输入的,只是scanf()以键盘(stdin)为输入源,sscanf()以固定字符串为输入源。

【实例】从指定的字符串中读取整数和小写字母。

#include <stdio.h>
int main(void)
{
  char str[100] ="123568qwerSDDAE";
  char lowercase[100];
  int num;
  sscanf(str,"%d %[a-z]", &num, lowercase);
  printf("The number is: %d.\n", num);
  printf("The lowercase is: %s.", lowercase);
  return 0;
}

输出结果:

The number is: 123568.
The lowercase is: qwer.

可以看到format参数有些类似正则表达式(当然没有正则表达式强大,复杂字符串建议使用正则表达式处理),支持集合操作,例如:

  •     %[a-z] 表示匹配a到z中任意字符,贪婪性(尽可能多的匹配)
  •     %[aB'] 匹配a、B、'中一员,贪婪性
  •     %[^a] 匹配非a的任意字符,贪婪性

另外,format不仅可以用空格界定字符串,还可以用其他字符界定,可以实现简单的字符串分割(更加灵活的字符串分割请使用strtok())。例如:

  sscanf("2006:03:18", "%d:%d:%d", a, b, c);
  sscanf("2006:03:18 - 2006:04:18", "%s - %s", sztime1, sztime2);

C语言vsscanf()函数:字符串输入函数
头文件:

 #include <stdio.h>

定义函数:

int vsscanf(const char * str, const char * format, va_list ap);

函数说明:vsscanf()会将参数str 的字符串根据参数format 字符串来转换并格式化数据. 格式转换形式请参考附录C 或vprintf()范例。

返回值:成功则返回参数数目, 失败则返回-1, 错误原因存于errno 中.

C语言vscanf()函数:字符串格式化输入函数
头文件:

#include <stdio.h>  #include <stdarg.h>

定义函数:

int vscanf(const char * format, va_list ap);

函数说明:vscanf()会将输入的数据根据参数format 字符串来转换并格式化数据. 格式转换形式请参考scanf(). 转换后的结果存于对应的参数内. va_list 用法请参考附录C 或vprintf()范例.
返回值成功则返回参数数目, 失败则返回-1, 错误原因存于errno 中。


上一篇:C语言中初始、增加和删除进程信号的操作方法简介

栏    目:C语言

下一篇:C语言编程中对目录进行基本的打开关闭和读取操作详解

本文标题:详解C语言sscanf()函数、vsscanf()函数、vscanf()函数

本文地址:https://www.xiuzhanwang.com/a1/Cyuyan/2783.html

网页制作CMS教程网络编程软件编程脚本语言数据库服务器

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:835971066 | 邮箱:835971066#qq.com(#换成@)

Copyright © 2002-2020 脚本教程网 版权所有