C语言利用sprintf固定字符串输出位数

目录
  • 一、前言
  • 二、案例
    • 【1】多个整数输出补齐
    • 【2】单个整数输出补齐
    • 【3】固定时间长度
    • 【4】浮点数补齐
    • 【5】onenet数据组合

一、前言

sprintf 函数是一个 C 语言中的函数,也被许多其他编程语言所支持。它允许你根据一组变量来格式化和存储一个字符字符串。sprintf 函数可以用于将格式化的数据写入字符数组或字符串中,然后根据需要打印或存储该字符串。sprintf 函数的第一个参数是格式化数据将被写入的字符数组或字符串,随后的参数是用于生成格式化输出的变量。sprintf 函数允许你控制输出的格式,包括小数点后的位数、字段的宽度和文本的对齐方式等。

在单片机项目开发中经常需要通过sprintf组合字符串,完成各种数据的打印,显示等等。

比如:

在单片机里通过LCD屏显示传感器数据的时候,如果不固定字符串长度,每次从传感器读取的数据长度可能都不一样,一般都会先清屏再显示,或者先使用空格清除显示,再显示实际数据。这种在LCD刷新频率比较低的情况下肉眼会看出屏幕闪烁的效果。 为了方便显示,我们可以使用sprintf固定最终数据的长度,预置好传感器最大输出的长度进行显示,后期采集的数据如果不够长度,就以空格补齐。这样调用显示函数就很方便了,不需要担心清屏问题。

二、案例

【1】多个整数输出补齐

我们读取到DS18B20温度,需要显示在LCD显示屏上。我们将得到的温度固定长度为5个字符的字符串,显示到LCD屏上。

char DS18B20_str[10];
DS18B20=readDs18b20();
sprintf(DS18B20_str, "%02d.%01d", DS18B20 >> 4, DS18B20 & 0xF);

这里,我们使用了%02d和%01d格式化字符串来指定输出数字的位数。%02d表示要输出两位数字,并在前面补零(如果需要),而%01d表示要输出一位数字。因此,上面的代码将会打印出一个形如"12.3 "(注意最后的空格)的字符串,其中数字部分总共有5个字符(包括小数点)。

【2】单个整数输出补齐

char mqtt_message[10];
water_hp=read_water_hp();
sprintf(mqtt_message, "%3d", water_hp);

这将把 water_hp 转换为一个 3 位宽的字符串,并根据需要在左边用空格填充。如果 water_hp 不足 3 位,它将被左侧填充空格以达到 3 位的宽度。

【3】固定时间长度

下面是一个将秒转为时分秒输出的C语言函数:

#include <stdio.h>
#include <string.h>
 ​
char* formatTime(int seconds) {
    static char timeStr[9]; // 时分秒格式化后最多占用8个字符,再加上'\0'结束符
    int hours, minutes;
    hours = seconds / 3600;
    seconds = seconds % 3600;
    minutes = seconds / 60;
    seconds = seconds % 60;
    snprintf(timeStr, sizeof(timeStr), "%02d:%02d:%02d", hours, minutes, seconds);
    return timeStr;
}
 ​
int main() {
    int seconds = 3661; // Example value
    char* timeStr = formatTime(seconds);
    printf("%s\n", timeStr);
    return 0;
}

这个程序中,formatTime 是我们创建的子函数,它接受一个整型参数 seconds,代表需要转换的总秒数。该函数计算出对应的小时、分钟和秒数,并使用 snprintf 函数将格式化后的时间字符串写入到 timeStr 数组中。

main 函数中,我们可以调用 formatTime 函数来进行测试,并将得到的字符串输出。注意,我们需要使用 %s 格式化字符串输出,并且需要使用 static 关键字声明 timeStr 数组,以便在函数返回后仍然可以访问。

【4】浮点数补齐

固定浮点数输出的长度。

double x = 123.456789;
printf("温度:%8.2f", x);

这段代码的作用是将变量 x 的值输出到屏幕上,同时格式化输出为一个浮点数(保留两位小数,并且右对齐,总宽度为8),前面加上“温度:”字样。

具体来说:

  • %8.2f 是格式化字符串,其中 %f 表示要输出的是一个浮点数,.2 表示要保留两位小数,而 8 则表示总宽度为8(不足部分右对齐,左边补空格)。
  • printf 函数中,我们使用 % 符号来引用这个格式化字符串,并将 x 作为参数传递进去。

【5】onenet数据组合

OneNet是由中国移动打造的物联网云平台,它提供了一个完整的物联网解决方案,包括设备接入、数据存储、数据分析和应用开发等功能。OneNet为用户提供了一系列的API,使得开发者能够轻松地将自己的设备连接到云端,并通过云端进行实时监测和控制。同时,OneNet还提供了强大的数据分析工具,帮助用户更好地理解和利用设备产生的海量数据。作为全球领先的物联网云平台之一,OneNet已经被广泛应用于智能家居、智慧城市、工业物联网等领域。

OneNet支持多种协议接入,其中局包括了HTTP协议,单片机可以利用HTTP配合WIFI或者GPRS模块向OneNet上传报文,而组合HTTP报文的时候,就需要填数据内容的长度,由于是采集传感器的数据组合报文上传,每次采集的传感器数据长度肯定会不一样,为了不再重复计算整个报文的字符串长度,我们可以利用sprintf固定数据的长度,这样每次组合的报文数据长度就是一致的,省去了单独计算长度的过程。

char OneNet_HTTP_CMD[1024];
#define ONENET_DEVICE_ID "1025640558"
#define ONENET_API_KEY "gOp2NkgQEt3=EQY7ei61suGjgIg="

/*
函数功能: 采用HTTP协议方式向OneNet服务器上报GPS经纬度信息
函数参数:
                char *data_point:数据点的名称
                double Longitude,double latitude:上传的经纬度数据
*/
void OneNet_HTTP_GPS_DataUpdate(double Longitude, double latitude)
{
    //拼接数据
    snprintf(OneNet_HTTP_CMD, sizeof(OneNet_HTTP_CMD),
        "POST /devices/%s/datapoints HTTP/1.1\r\n" \
        "api-key:%s\r\n" \
        "Host:api.heclouds.com\r\n" \
        "Connection:close\r\n" \
        "Content-Length:160\r\n" \
        "\r\n" \
        "{"datastreams":[{"id":"gps","datapoints":[{"value":{"lon":%8.6f,"lat":%8.6f}}]},{"id":"gps2","datapoints":[{"value":{"lon":%10.6f,"lat":%10.6f}}]}]}",
        ONENET_DEVICE_ID, ONENET_API_KEY, Longitude, latitude, Longitude, latitude);
 ​
    printf("GPS_OneNet_HTTP_CMD=%s\r\n", OneNet_HTTP_CMD);

    printf("%s\r\n", OneNet_HTTP_CMD);
}
​

int main()
{
    OneNet_HTTP_GPS_DataUpdate(Longitude,latitude);
    return 0;
}

到此这篇关于C语言利用sprintf固定字符串输出位数的文章就介绍到这了,更多相关C语言sprintf内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C++中sprintf使用的方法与printf的区别分析

    本文实例讲述了C++中sprintf使用的方法与printf的区别.分享给大家供大家参考.具体分析如下: 首先我们在MSDN看一下printf的原型和sprintf的原型 复制代码 代码如下: int printf( const char *format [, argument]... ); 和 复制代码 代码如下: int sprintf( char *buffer, const char *format [, argument] ... ); 从定义来看两者的功能其实很相似的. 如果你接触的

  • 浅析C语言中printf(),sprintf(),scanf(),sscanf()的用法和区别

    printf语法: #include <stdio.h>int printf( const char *format, ... ); printf()函数根据format(格式)给出的格式打印输出到STDOUT(标准输出)和其它参数中.返回值是输出的字符数量.sprintf语法: #include <stdio.h>int sprintf( char *buffer, const char *format, ... );sprintf()函数和printf()类似,格式控制完全一样

  • C语言 sprintf 函数详情

    目录 一.sprintf 函数简介 二.sprintf 函数使用 三.sprintf/fprintf/printf 函数区别 一.sprintf 函数简介 sprintf 函数用于将格式化的数据写入字符串,其原型为: #include <stdio.h> /* *描述:将格式化的数据写入字符串 * *参数: * [out] str: 输出缓冲区,得到格式化之后的字符串; * [in] format: 格式化字符串,与 printf 函数一样; * *返回值:如果成功,则返回写入的字符总数,不包

  • 基于C语言sprintf函数的深入理解

    printf 可能是许多程序员在开始学习C语言时接触到的 第二个函数(我猜第一个是main),说起来,自然是老朋友了,可是,你对这个老朋友了解多吗?你对它的那个孪生兄弟sprintf了解多吗?在将各种类 型的数据构造成字符串时,sprintf的强大功能很少会让你失望.由于sprintf跟printf在用法上几乎一样,只是打印的目的地不同而已,前者打印到字符串中,后者则直接在命令行上输出.这也导致sprintf比printf有用得多.所以本文着重介绍sprintf,有时也穿插着用用 pritnf.

  • C语言利用sprintf固定字符串输出位数

    目录 一.前言 二.案例 [1]多个整数输出补齐 [2]单个整数输出补齐 [3]固定时间长度 [4]浮点数补齐 [5]onenet数据组合 一.前言 sprintf 函数是一个 C 语言中的函数,也被许多其他编程语言所支持.它允许你根据一组变量来格式化和存储一个字符字符串.sprintf 函数可以用于将格式化的数据写入字符数组或字符串中,然后根据需要打印或存储该字符串.sprintf 函数的第一个参数是格式化数据将被写入的字符数组或字符串,随后的参数是用于生成格式化输出的变量.sprintf 函

  • Go语言利用Unmarshal解析json字符串的实现

    简单的解析例子: 首先还是从官方文档中的例子: package main import (     "fmt"     "encoding/json" ) type Animal struct {     Name  string     Order string } func main() {     var jsonBlob = []byte(`[         {"Name": "Platypus", "Or

  • Go语言fmt.Sprintf格式化输出的语法与实例

    格式化在逻辑中非常常用.使用格式化函数,要注意写法: fmt.Sprintf(格式化样式, 参数列表…) 格式化样式:字符串形式,格式化动词以%开头. 参数列表:多个参数以逗号分隔,个数必须与格式化样式中的个数一一对应,否则运行时会报错. 在 Go 语言中,格式化的命名延续C语言风格: var progress = 2 var target = 8 // 两参数格式化 title := fmt.Sprintf("已采集%d个药草, 还需要%d个完成任务", progress, targ

  • php常用字符串输出方法分析(echo,print,printf及sprintf) 原创

    本文讲述了php常用字符串输出方法.分享给大家共大家参考,具体如下: 1. echo用法:可用echo 直接输出,也可以用echo()输出,无返回值 $string="<b>加粗显示文字</b>"; echo $string; //echo "<br/>"; //echo($string);//效果同上 echo "<br/>"; echo "This ", "is &

  • C语言嵌入式实现支持浮点输出的printf示例详解

    目录 简介 背景 C语言可变参数函数 踩坑 功能实现 简介 mr-printf 模块为 mr-library 项目下的可裁剪模块,以C语言编写,可快速移植到各种平台(主要以嵌入式mcu为主). mr-printf 模块用以替代 libc 中 printf, 可在较小资源占用的同时支持绝大部分 printf 功能,于此同时还支持对单独功能模块的裁剪以减少用户不需要功能的资源占用. 背景 printf 大家应该使用的比较多,但是在嵌入式平台中,尤其是单片机中,libc中的printf对内存的占用较高

  • c语言 数据结构实现之字符串

    c语言 数据结构实现之字符串 串采用定长顺序存储结构(由c4-1.h定义)的基本操作(13个),包括算法4.2,4.3,4.5   实现效果图: #include <stdio.h> #include <string.h> #include <malloc.h> // SString是数组,故不需引用类型 #define OK 1 #define TRUE 1 #define FALSE 0 #define ERROR 0 #define INFEASIBLE -1 #

  • 利用ScriptEngineManager实现字符串公式灵活计算的方法

    在开发中我们可能会遇到好多不固定的公式计算 如有时候我们需要将excel中大量的计算公式转换成java语言进行实现 如果说单纯的用java的基本方法实现计算 我们就需要的分析excel中的公式将其一一并转换成java代码 这样对我们开发人员来说工作量有点太大了 而且在转换过程中很可能会出错 下面就介绍一种简单的实现方法 我们知道js的eval()方法可以执行字符串的代码 而恰好jdk6增加了对脚本语言的支持 我们可以利用这个特性对计算实现简单化的处理 下面举个例子 加入有个公式 A+B*C A=

  • C语言利用system调用系统命令行详情

    system,顾名思义,就是调用系统命令行,输入为字符串,然后把这个字符串输出给命令行,让命令行执行. 为了测试其特性,可以做一个小程序: //system.c #include<stdlib.h> #include<stdio.h> #include<string.h> int main(){     char cmd[100];     while(1){         printf("input code: ");         gets(

  • C语言超详细讲解字符串相乘

    目录 前言 一. 分析思路 二.使用步骤 1.代码如下 2.memset函数 三.总结 前言 我们已经知道,正常的两位整形数据通过*相乘,C语言中int为4字节,32bit(字节),其机器码第一位为符号位,余下31位表示数字,表示范围:-2^31(-2147483648)~2^31-1(2147483647),但超过了这个范围我们该如何做呢? 提示:将数字以字符串的形式进行操作 一. 分析思路 示例: 我们把每一个数都看成是一个字符串,每一个元素为十进制数字所对应的字 符,由于是后面的元素先进行

  • Go语言利用接口实现链表插入功能详解

    目录 1. 接口定义 1.1 空接口 1.2 实现单一接口 1.3 接口多方法实现 2. 多态 2.1 为不同数据类型的实体提供统一的接口 2.2 多接口的实现 3. 系统接口调用 4. 接口嵌套 5. 类型断言 5.1 断言判断 5.2 多类型判断 6. 使用接口实现链表插入 1. 接口定义 Interface 类型可以定义一组方法,不需要实现,并且不能包含任何的变量,称之为接口 接口不需要显示的实现,只需要一个变量,含有接口类型中的所有方法,那么这个变量就实现了这个接口,如果一个变量含有多个

随机推荐