博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
sscanf函数的高级用法
阅读量:5077 次
发布时间:2019-06-12

本文共 1536 字,大约阅读时间需要 5 分钟。

转载时请注明出处:

 

大家都知道sscanf是一个很好用的函数,利用它可以从字符串中取出整数、浮点数和字符串等等。它的使用方法简单,特别对于整数和浮点数来说。但新手可能并不知道处理字符串时的一些高级用法,这里做个简要说明吧。

 

1.         常见用法。

char str[512] = {0};

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

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

 

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

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

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

 

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

    sscanf("123456 abcdedf", "%[^ ]", str);

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

 

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

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

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

 

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

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

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

 

例程:

 
/*
************************************************************************
* Filename: sscanf.c
* Description:
* Version: 1.0
* Created: 2011年05月05日 15时19分05秒
* Revision: none
* Compiler: gcc
* Author: wenhao (wh), hnrain1004@gmail.com
* Company: sunplusapp
* ***********************************************************************
*/
#include
<
stdio.h
>
#include
<
stdlib.h
>
#include
<
unistd.h
>
int
main(
int
argc,
char
*
argv[])
{
char
str[
512
]
=
""
;
sscanf(
"
12345
"
,
"
%s
"
,str);
printf(
"
str1=%s\n
"
,str);
sscanf(
"
12345
"
,
"
%4s
"
,str);
printf(
"
str2=%s\n
"
,str);
sscanf(
"
123456 abcdef
"
,
"
%[^ ]
"
,str);
printf(
"
str3=%s\n
"
,str);
sscanf(
"
123456abcdBefgABCDEF
"
,
"
%[1-9a-z]
"
,str);
printf(
"
str4=%s\n
"
,str);
sscanf(
"
123456abcdefABCDE
"
,
"
%[^A-Z]
"
,str);
printf(
"
str4=%s\n
"
,str);
return
0
;
}

运行结果:

2011050515380021.png

~~~end~~

转载于:https://www.cnblogs.com/hnrainll/archive/2011/05/05/2037737.html

你可能感兴趣的文章
第四讲 深入介绍信号与槽
查看>>
.gitignore梳理
查看>>
Lucene/Solr搜索引擎开发笔记 - 写作方向调整
查看>>
JavaScript 数据类型小结
查看>>
-webkit-overflow-scrolling:touch iosBug
查看>>
HDU2028:Lowest Common Multiple Plus
查看>>
辞树的QAQ水题(字符串统计,思维)
查看>>
python自动化之路 day5-1 paramiko模块
查看>>
安全证书的问题
查看>>
习题3.4 最长连续递增子序列(20 分)浙大版《数据结构(第2版)》题目集
查看>>
Browser
查看>>
virtualbox主机与虚拟机之间互相通信教程
查看>>
NotificationManager和Notification的使用总结
查看>>
Linux系统上安装JDK1.8
查看>>
iOS 复杂tableView的 cell一般设计思路
查看>>
BZOJ 1452 Count 【模板】二维树状数组
查看>>
数据库一些小知识
查看>>
角色扮演
查看>>
springmvc基础学习2---简单配置文件
查看>>
javascript是做什么的
查看>>