完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
记录日志主要是将运行中的数据转换为字符串,然后再写入到SD卡。需要解决两个问题:
程序中各种格式的数据变量转换为字符串; SD卡文件关闭后再次打开继续接着写。 解决第一个问题是使用函数sprintf(),函数具体定义和用法请看C标准库。 “%02d”是输出2位宽度的十进制,“%.1f”是输出浮点数小数点保留1位,其他类推。 //每天中午12点记录一次传感器数据 void Write_Log(void) { if((Bm_Date.hour == 12)&&(Bm_Date.minute == 0)) { sprintf(str_zt,"20%02d%02d%02d %02d:%02d:%02d T:%.1f RH:%.1f%%nPM2.5:%.1fug/m3 PM10:%.3fmg/m3 TVOC:%.4fmg/m3 HCHO:%.3fmg/m3 NH3:%.3fmg/m3 H2S:%.1fppmn",Bm_Date.year,Bm_Date.month,Bm_Date.day,Bm_Date.hour,Bm_Date.minute,Bm_Date.second,Temperature,Humidity,PM2D5,PM10,TVOC,CH2O,NH3,H2S); printf("%s",str_zt); Write_TFCard(); } } “sprintf()”函数是将字符串和各种变量按照格式输出到一个字符串str_zt里,输出完毕后效果就是将分散的信息连接到了一起。另外该函数返回值是连接的总字节数,使用起来非常方便。然后再打印printf("%s",str_zt),效果就是下面这样子。 20210117 22:23:00 T:0.0 RH:0.0% PM2.5:0.0ug/m3 PM10:0.000mg/m3 TVOC:0.0000mg/m3 HCHO:0.000mg/m3 NH3:0.000mg/m3 H2S:0.0ppm 解决第二个问题是使用f_lseek(&fil,n)函数。该函数是将文件指针从文件头向下偏移n个字节。 另外必须注意f_open文件打开方式,FA_OPEN_ALWAYS | FA_WRITE。如果是用了FA_CREATE_ALWAYS | FA_WRITE,是不行的,会覆盖上次写的文件重新建个文件。 void Write_TFCard(void) { printf("rn ****** 文件系统 ******rnrn"); /*-1- 挂载文件系统*/ retSD = f_mount(&fs, "", 0); if(retSD) { printf(" mount error : %d rn",retSD); Error_Handler(); } else printf(" mount sucess!!! rn"); /*-2-创建新的文件并写入数据*/ retSD = f_open(&fil, filename, FA_OPEN_ALWAYS | FA_WRITE); //打开文件,权限包括创建、写(如果没有该文件,会创建该文件) if(retSD) //返回值不为0(出现问题) printf(" open file error : %drn",retSD); //打印问题代码 else printf(" open file sucess!!! rn"); /*-3- 偏移指针到末尾处*/ printf(" file size: %d rn",(int)fil.fsize); f_lseek(&fil,fil.fsize); /*-4- 在txt文件尾续写数据*/ retSD = f_write(&fil, str_zt, sizeof(str_zt), (void *)&byteswritten); //在文件内写入wtext内的内容 if(retSD) //返回值不为0(出现问题) printf(" write file error : %drn",retSD); //打印问题代码 else { printf(" write file sucess!!! rn"); printf(" write Data : %srn",str_zt); //打印写入的内容 } /*-5- 关闭txt文件*/ retSD = f_close(&fil); //关闭该文件 if(retSD) //返回值不为0(出现问题) printf(" close error : %drn",retSD); //打印问题代码 else printf(" close sucess!!! rn"); } 以上程序合在一起运行打印效果如下: 这两个简单函数即实现了将多种变量信息保存记录到SD卡里,至于什么时间记录,多久记录一次,就自己定了。 最后将SD卡放电脑上,记事本打开看看: |
|
|
|
只有小组成员才能发言,加入小组>>
imx6ull 和 lan8742 工作起来不正常, ping 老是丢包
3363 浏览 0 评论
3370 浏览 9 评论
3061 浏览 16 评论
3551 浏览 1 评论
9182 浏览 16 评论
1305浏览 3评论
671浏览 2评论
const uint16_t Tab[10]={0}; const uint16_t *p; p = Tab;//报错是怎么回事?
663浏览 2评论
用NUC131单片机UART3作为打印口,但printf没有输出东西是什么原因?
2411浏览 2评论
NUC980DK61YC启动随机性出现Err-DDR是为什么?
1978浏览 2评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-2-24 09:19 , Processed in 1.624468 second(s), Total 76, Slave 57 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191