Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
文件系统学习营
【文件系统学习】+小燕+将系统log日志保存为csv文件
发布于 2018-07-18 00:05:01 浏览:2359
订阅该版
```将系统log日志保存为csv文件,存储到SD卡中,通过winimage提取出csv文件,可以通过excel打开;``` 下载附件 [5.doc](https://oss-club.rt-thread.org/uploads/201807/18/000259l4vm2ezkkkk4dkdo.attach)
查看更多
4
个回答
默认排序
按发布时间排序
lillian
2018-07-18
这家伙很懒,什么也没写!
``` /* * 程序清单:将系统log日志保存为csv文件 * * 程序会创建一个操作文件的函数并导出到msh命令列表 * 将系统log日志保存为csv文件 * */ #include
#include
/* 当需要使用文件操作时,需要包含这个头文件 */ #include
#define LOG_CSV_FILE_NAME "log.csv" // 将系统log即通过rt_kprintf输出的log信息保存一份到log.csv文件中 void log_csv(const char *buf) { uint8_t scheduler_started = 0; char *fullpath, *path; struct dfs_fd fd; struct stat file_stat; // 等待系统调度开始 文件系统正常挂载 scheduler_started = rt_get_scheduler_stat(); if (!scheduler_started) { return; } // 写log到csv文件 // 文件路径 #ifdef DFS_USING_WORKDIR path = rt_strdup(working_directory); #else path = rt_strdup("/"); #endif if (path == NULL) return ; // 路径+文件名 fullpath = dfs_normalize_path(path, LOG_CSV_FILE_NAME); if (fullpath == NULL) { rt_free(path); return; } // 打开文件 if (dfs_file_open(&fd, fullpath, O_CREAT | O_RDWR)) { rt_free(path); return; } // 写log到文件 // 获取文件信息 if (dfs_file_stat(fullpath, &file_stat)) { dfs_file_close(&fd); rt_free(path); return; } // 定位到文件末尾 if (dfs_file_lseek(&fd, file_stat.st_size) < 0) { dfs_file_close(&fd); rt_free(path); return; } // 写日志 if (dfs_file_write(&fd, buf, strlen(buf)) < 0) { dfs_file_close(&fd); rt_free(path); return; } dfs_file_close(&fd); rt_free(path); } /* 导出到 msh 命令列表中 */ MSH_CMD_EXPORT(log_csv, add log.csv to SD); ```
lillian
2018-07-18
这家伙很懒,什么也没写!
``` /** * @ingroup rt_get_scheduler_stat * This function will return 1 if the scheduler started, 0 if not; * */ uint8_t rt_get_scheduler_stat(void) { return xSchedulerRunning; } ```
lillian
2018-07-18
这家伙很懒,什么也没写!
``` /** * This function will print a formatted string on system console * * @param fmt the format */ void rt_kprintf(const char *fmt, ...) { va_list args; rt_size_t length; static char rt_log_buf[RT_CONSOLEBUF_SIZE]; va_start(args, fmt); /* the return value of vsnprintf is the number of bytes that would be * written to buffer had if the size of the buffer been sufficiently * large excluding the terminating null byte. If the output string * would be larger than the rt_log_buf, we have to adjust the output * length. */ length = rt_vsnprintf(rt_log_buf, sizeof(rt_log_buf) - 1, fmt, args); if (length > RT_CONSOLEBUF_SIZE - 1) length = RT_CONSOLEBUF_SIZE - 1; #ifdef RT_USING_DEVICE if (_console_device == RT_NULL) { rt_hw_console_output(rt_log_buf); } else { rt_uint16_t old_flag = _console_device->open_flag; _console_device->open_flag |= RT_DEVICE_FLAG_STREAM; rt_device_write(_console_device, 0, rt_log_buf, length); _console_device->open_flag = old_flag; } #if RT_USING_SAMPLE_LOG_CSV // 添加日志到csv文件 log_csv(rt_log_buf); #endif #else rt_hw_console_output(rt_log_buf); #endif va_end(args); } ```
whj467467222
认证专家
2018-08-13
开源,分享,交流,共同进步
请问一下我使用命令行 ``` echo "hello rt_thread \r\n" hello.cvs ``` 可以正常创建hello.cvs,但是无法使用换行
撰写答案
登录
注册新账号
关注者
0
被浏览
2.4k
关于作者
lillian
这家伙很懒,什么也没写!
提问
17
回答
49
被采纳
0
关注TA
发私信
相关问题
1
【文件系统学习】+DMY+任务1sample例程
2
【文件系统学习】skawu的文件系统跑起来了
3
【文件系统学习】bin5219在qemu-vexpress-a9 中运行一个.c
4
【文件系统学习】skawu之文件匹配学习
5
【文件系统学习】+海中陆地+成功运行文件系统,并运行文...
6
【文件系统学习】+清石+运行文件系统sample例程
7
【文件系统学习】+小燕+运行文件系统sample例程
8
【文件系统学习】+阿暖+运行文件系统 sample 例程
9
【文件系统学习】+小燕+一系列文件中找出指定文件
10
【文件系统学习】+小燕+文件数据替换
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
CherryUSB的bootuf2配置
2
在用clangd开发RTT吗,快来试试如何简单获得清晰干净的工作区
3
GD32F450 片内 flash驱动适配
4
STM32H7R7运行CherryUSB
5
RT-Smart首次线下培训,锁定2024 RT-Thread开发者大会!
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
UART
WIZnet_W5500
ota在线升级
PWM
freemodbus
flash
cubemx
packages_软件包
BSP
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
中断
编译报错
Debug
SFUD
rt_mq_消息队列_msg_queue
msh
keil_MDK
ulog
C++_cpp
MicroPython
本月问答贡献
a1012112796
10
个答案
1
次被采纳
踩姑娘的小蘑菇
4
个答案
1
次被采纳
红枫
4
个答案
1
次被采纳
张世争
4
个答案
1
次被采纳
Ryan_CW
4
个答案
1
次被采纳
本月文章贡献
catcatbing
3
篇文章
6
次点赞
YZRD
2
篇文章
5
次点赞
lizimu
2
篇文章
5
次点赞
qq1078249029
2
篇文章
2
次点赞
xnosky
2
篇文章
1
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部