C语言奇技Y巧之sscanf函数用法详解

目录

  • sscanf函数介绍
  • 一般用法:读取字符串、整型、浮点数
  • sscanf 使用正则表达式
  • sscanf 返回-1
  • sscanf 解析失败处理
  • sscanf 缺点

sscanf函数介绍

sscanf,C语言中的函数,读取格式化的字符串中的数据。

#include <stdio.h>
int sscanf(const char *str, const char *format, ...);

str:待解析的字符串;
format:字符串格式描述;
…:其后是一序列数目不定的指针参数,存储解析后的数据;
返回值:成功则返回解析参数数目,失败则返回-1,错误原因存于errno中。

一般用法:读取字符串、整型、浮点数

1、读取字符串,遇到空格停止,可指定最大读取字符个数,防止溢出。

    char buf[128] = {0};sscanf("1234#$%^&*/56ab  7c", "%20s", buf);printf("%s\n", buf);//sscanf 默认遇到空格停止,若要读取空格可以使用%[ ]

打印

1234#$%^&*/56ab

2.读取整型,固定长度格式读取每一段数据

    int year, month, day;int converted = sscanf("20191103", "%4d%2d%2d", &year, &month, &day);printf("converted=%d, year=%d, month=%d, day=%d\n", converted, year, month, day);

打印

converted=3, year=2019, month=11, day=3

3.读取浮点数,可以格式化保存小数点位数

    double lon, lat;int converted2 = sscanf("118.123456789 32.123456789", "%lf %lf", &lon, &lat);printf("converted2=%d, lon=%.9lf, lat=%lf\n", converted2, lon, lat);//%.9lf指定保存小数点9位,%lf默认保存6位,第七位四舍五入

打印

converted2=2, lon=118.123456789, lat=32.123457

sscanf 使用正则表达式

sscanf对正则表达式的支持不是特别强大,但大部分基本正则功能可以实现。

1.%[a-z] 读取在 a-z 之间的字符串,如果不在此之间则停止。

    char str[128] = "";//读取0-9和a-z和#字符,遇到不是这些字符时停止,E不属于所以停止读取sscanf("123#abc456#dEF789gh", "%31[0-9a-z#]", str);printf("str=%s\n", str);

打印

str=123#abc456#d

2.%[^a-z] 读取不在 a-z 之间的字符串,如果碰到a-z之间的字符则停止

    char str2[128] = "";//读取非a-z#字符,遇到a-z#字符时停止,这里遇到#停止读取sscanf("123#abc456#dEF789gh", "%31[^a-z#]", str2);printf("str2=%s\n", str2);

打印

str2=123

3.%*[^1-9] 前面带 * 号表示不保存变量,跳过符合条件的字符串。

    char str3[128] = "";//%*[^a-z#]读取非a-z#字符,遇到a-z#字符时停止,且不保存;%s继续读取后面所以字符sscanf("123#abc456#dEF789gh", "%*[^a-z#]%s", str3);printf("str3=%s\n", str3);

打印

str3=#abc456#dEF789gh

4.复合用法,同时读取多个字符串和整数

    std::string msg = "msg:123,ab c,456,D\"ef222";//分别读取字符串和整数,字符串包含空格和"符号char msg1[16];char msg2[16];int int1;int int2;//success=4,成功读取4个字段//%*[^:]前面的msg:不要,读取非:字符,遇到:停止,且不保存//%[a-z ]读取a-z的字符和空格,遇到其他字符则停止//%[a-zA-Z\"]读取a-z和A-Z和"字符,遇到其他字符则停止int success = sscanf(msg.c_str(),"%*[^:]:%d,%[a-z ],%d,%[a-zA-Z\"]",&int1, msg1, &int2, msg2);printf("success=%d\n",success);printf("msg1=%s\n", msg1);printf("msg2=%s\n", msg2);printf("int1=%d\n",int1);printf("int2=%d\n",int2);

打印

success=4
msg1=ab c
msg2=D"ef
int1=123
int2=456

获取 / 和 @ 之间的字符串

    char buf2[128] = {0};//%*[^/]读取非/字符,遇到/停止,这里读取了iios,且不保存//%[^@]读取非@字符,遇到@停止sscanf("iios/12DDWDFFabc@122", "%*[^/]/%[^@]", buf2);printf("buf2=%s\n", buf2);

打印

buf2=12DDWDFFabc

sscanf 返回-1

当sscanf第一个参数为空字符串,或第二个参数为空指针,sscanf 返回-1。
如果sscanf第一个参数为空指针,程序会崩溃。

    int b1;int ret_b = sscanf("123",NULL,&b1);printf("ret_b=%d,b1=%d,err=%d(%s)\n",ret_b, b1, errno, strerror(errno));int b2;ret_b = sscanf("","%d",&b2);printf("ret_b=%d,b2=%d,err=%d(%s)\n",ret_b, b2, errno, strerror(errno));

打印

ret_b=-1,b1=32766,err=22(无效的参数)
ret_b=-1,b2=436341776,err=0(成功)

sscanf 解析失败处理

如果sscanf参数语法格式没问题,不会返回-1,返回解析成功的字段个数,一个都没成功返回0。

当遇到解析失败, sscanf 会停止后面的解析,本例只解析成功了a1,解析a2时失败并停止读取,返回1,打印的a2和a3是未初始化的乱码。

    int a1;int a2;int a3;int ret_a = sscanf("123,a,456", "%d,%d,%d", &a1, &a2, &a3);printf("ret_a=%d,a1=%d,a2=%d,a3=%d\n",ret_a,a1,a2,a3);

打印

ret_a=1,a1=123,a2=1528212112,a3=32766

sscanf 缺点

1.不同操作系统对 sscanf 的支持不同,移植时可能出现bug。
2.复杂字符串处理容易出错,可读性差,不易调试。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/692240.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

图片怎么变成透明背景?分享这些变透明的方法

很多从事编辑和图片设计的同行在日常工作中经常需要处理图片的背景色。为了更好地进行设计和编辑&#xff0c;将图片的背景色替换成透明是非常必要的。然而&#xff0c;对于一些新手来说&#xff0c;使用专业的图像处理软件可能有些困难。不过&#xff0c;现在有很多在线的图像…

N5182A MXG 矢量信号发生器,100 kHz 至 6 GHz

N5182A MXG 矢量信号发生器 简述&#xff1a; Agilent N5182A 具有快速频率、幅度和波形切换、带有电子衰减器的高功率和高可靠性——所有这些都在两个机架单元 (2RU) 中。安捷伦 MXG 矢量针对制造蜂窝通信和无线连接组件进行了优化。安捷伦 MXG 矢量通过增加吞吐量、提高测试良…

Elasticsearch:什么是 kNN?

kNN - K-nearest neighbor 定义 kNN&#xff08;即 k 最近邻算法&#xff09;是一种机器学习算法&#xff0c;它使用邻近度将一个数据点与其训练并记忆的一组数据进行比较以进行预测。 这种基于实例的学习为 kNN 提供了 “惰性学习&#xff08;lazy learning&#xff09;” 名…

IO进程:多进程实现文件的拷贝

1.使用多进程完成两个文件的拷贝&#xff0c;父进程拷贝前一半&#xff0c;子进程拷贝后一半&#xff0c;父进程回收子进程的资源 程序代码&#xff1a; 1 #include<myhead.h>2 int main(int argc, const char *argv[])3 {4 //判断传入的文件个数5 if(argc!3)6 …

nginx upstream server主动健康监测模块添加https检测功能【上】

1 缘起 前面的《nginx upstream server主动健康检测模块ngx_http_upstream_check_module 使用和源码分析》系列已经分析了ngx_http_upstream_check_module的实现原理&#xff0c;并且在借助这个模块的框架实现了一个udp健康检测的新功能。   但是ngx_http_upstream_check_mod…

Arcmap excel转shp

使用excel表格转shp的时候&#xff0c;如果你的excel里面有很多字段&#xff0c;直接转很大概率会出现转换结果错误的情况&#xff0c;那么就需要精简一下字段的个数。将原来的表格文件另存一份&#xff0c;在另存为的文件中只保留关键的经度、纬度、和用于匹配的字段即可&…

LeetCode JS专栏刷题笔记(一)

一、前言 LeetCode 在前不久出了一个 JavaScript 专栏&#xff0c;这个专栏一个目的是为了非前端工程师学习 JS&#xff0c;另一个是为了前端工程师提升 JS 能力。 因此在这个专栏中&#xff0c;基本不涉及什么具体算法问题&#xff0c;都是一些 JS 的入门语法与常见的 JS 面…

redis分布式锁redisson

文章目录 1. 分布式锁1.1 基本原理和实现方式对比synchronized锁在集群模式下的问题多jvm使用同一个锁监视器分布式锁概念分布式锁须满足的条件分布式锁的实现 1.2 基于Redis的分布式锁获取锁&释放锁操作示例 基于Redis实现分布式锁初级版本ILock接口SimpleRedisLock使用示…

前端秘法基础式终章----欢迎来到JS的世界

目录 一.JavaScript的背景 二.JavaScript的书写形式 1.行内式 2.嵌入式 3.外部式 三.JS中的变量 1.变量的定义 2.JS动态类型变量 2.1强类型和弱类型 3.JS中的变量类型 四.运算符 五.if语句和三元表达式和Switch语句和循环语句 六.数组 1.创建获取数组元素 2.新增…

2.20数据结构与算法学习日记(二叉树第一部分)

1.树的表示 typedef int DadaType; struct Node{struct Node* firstChild;struct Node* pnextBrotherDataType data; };//树的表示 2.二叉树的简介 二叉树是一种树形数据结构&#xff0c;每个节点最多有两个子节点&#xff0c;分别称为左子节点和右子节点。二叉树具有以下特…

现有的通用模型中融入少量中文数据没有太大意义少量的数据就能影响整个大模型

相关链接&#xff1a;只修改一个关键参数&#xff0c;就会毁了整个百亿参数大模型&#xff1f; | 新程序员-CSDN博客 现象 1&#xff1a;mBERT 模型的跨语言迁移 现象 2&#xff1a;大语言模型同样存在显著的语言对齐 现象 3&#xff1a;知识与语言分离 现象 4&#xff1a;…

unity学习(28)——登录功能

有之前注册的知识&#xff0c;登录就很容易处理了。 登陆成功返回id&#xff1a; 登录失败返回null&#xff1a; 测试同一账号不能重复登陆&#xff01;登录成功后最好可以跳到新的场景中 结果是好的&#xff0c;去服务器看一下对应部分的代码&#xff0c;可见&#xff0c;登…

MySQL错误-this is incompatible with sql_mode=only_full_group_by完美解决方案

项目场景 有时候&#xff0c;遇到数据库重复数据&#xff0c;需要将数据进行分组&#xff0c;并取出其中一条来展示&#xff0c;这时就需要用到group by语句。 但是&#xff0c;如果mysql是高版本&#xff0c;当执行group by时&#xff0c;select的字段不属于group by的字段的…

【FastAPI】P3 请求与响应

目录 请求路径参数查询参数 响应JSON 响应文本响应返回 Pydantic 模型 在网络通讯中&#xff0c;请求&#xff08;Request&#xff09; 与 响应&#xff08;Response&#xff09; 扮演着至关重要的角色&#xff0c;它们构成了客户端与服务器间互动的根本理念。 请求&#xff0…

代码随想录训练营第三十期|第三十七天|贪心算法 part06|● 738.单调递增的数字 ● 968.监控二叉树 ● 总结

738. 单调递增的数字 - 力扣&#xff08;LeetCode&#xff09; class Solution {public int monotoneIncreasingDigits(int n) {String s String.valueOf(n);char[] chars s.toCharArray();int start s.length();for (int i s.length() - 2; i > 0; i--) {if (chars[i]…

60秒表达力训练法:快速提高表达能力,摆脱嘴笨带来的困扰

60秒表达力训练法&#xff1a;快速提高表达能力&#xff0c;摆脱嘴笨带来的困扰 很多人由于缺乏结构意识&#xff0c;总是很难把一部电影、一件刚看到的事&#xff0c;说得清清楚楚&#xff0c;这往往并不是逻辑能力的问题。 比如&#xff0c;很多程序员逻辑能力非常强&#…

Linux编辑器——Vim详解

目录 ⭐前言 ⭐vim的基本概念 ⭐vim的基本操作 ⭐vim命令模式命令集 ⭐vim末行模式命令集 ⭐简单vim配置 ⭐配置文件的位置 ⭐常用配置选项 ⭐前言 vi/vim的区别简单点来说&#xff0c;它们都是多模式编辑器&#xff0c;不同的是vim是vi的升级版本&#xff0c;它不仅兼容…

LeetCode刷题笔记之二叉树(二)

一、二叉树的翻转 1. 226【翻转二叉树】 题目&#xff1a; 给你一棵二叉树的根节点 root &#xff0c;翻转这棵二叉树&#xff0c;并返回其根节点。代码&#xff1a; class Solution {public TreeNode invertTree(TreeNode root) {//翻转二叉树&#xff0c;实际上就是交换左…

CMake的简单使用

一、一个最简单的CMake项目 在Ubuntu上使用CMake构建一个最简单的项目。 1. 安装CMake 首先安装CMake&#xff0c;这里使用的是Ubuntu系统。 sudo apt-get install cmake2. 编写源程序 编写代码&#xff0c;新建文件main.c。 // main.c #include "stdio.h"int …

Java学习笔记2024/2/20

今日作业&#xff1a; 题目1 完成课堂上所有练习 package test.test1; ​ import java.util.Random; ​ public class Test3 { ​public static void main(String[] args) {//键盘输入任意字符串&#xff0c;打乱里面的内容 ​//1.键盘输入任意字符串String str "abcd…