程序实现很简单,涉及到的只有两个知识点。

1、文件最最基本的打开关闭;
2、系统时间的获取。

代码是在VS2019环境下编写的,部分函数在其他编译器中会无法识别。这个就只能需要自己去查找对应的函数简单修改即可。

如果遇到问题,欢迎大家提出来一起讨论。

文件操作:

先来介绍一下 文件操作 的基本方法。
操作文件必须遵从的过程是:打开读写关闭
一个文件首先要知道的是 文件名,当然你也可以新建一个文件。
如果是不同路径下的文件,还需要知道文件的路径。为了方便,本文采用同一目录下操作来说明。

只知道文件名并没什么用处,重要的是要通过文件名得到 文件结构体 FILE 的变量,里面会保存文件的一些基本但重要的信息。然后通过它来进行下一步的读写。

先来看一下文件操作的简单代码示例,后面再介绍函数的功能。

 #include <stdio.h>

 int main(void) {
FILE* stream;// 文件指针
errno_t err;// 错误码
char* filename = "file.txt";// 文件名
// 打开,以在文件末尾追加(append)数据的形式打开文件filename
err = fopen_s(&stream, filename, "a");
if (err == ) {
printf("文件 %s 打开成功\n", filename);
} else {
printf("文件 %s 打开失败\n", filename);
}
// 读写
if (stream != NULL) {
// 向文件末尾追加一段文字。
fprintf(stream, "%s", "文件操作成功!\n");
}
// 关闭
if (stream != NULL) {
// 关闭文件指针,先要判断是否为空
err = fclose(stream);
if (err == ) {
printf("文件 %s 关闭成功\n", filename);
} else {
printf("文件 %s 关闭失败\n", filename);
}
}
}
打开文件用到的是 fopen_s 函数,函数语法如下:
errno_t fopen_s(
FILE** pFile, // 一个指向文件指针的指针,它将接收指向打开的文件的指针。
const char *filename, // 文件名
const char *mode // 文件打开的方式,方式有很多种,可参考上面的链接。
);

如果打开成功返回 0,否则返回相应的错误码。

写数据用到的函数是 fprintf,语法如下:

int fprintf(
FILE *stream, // 文件指针
const char *format [, // 格式控制字符串
argument ]... // 可选参数
);

类似 printf 函数,只不过多了个文件指针而已。很好理解。
返回值是写入的字节数,通常用不到,可忽略。
当然,不止这一个函数可以写操作,还有 fwrite 函数,fputs 函数等等。

关闭文件用的是 fclose 函数,语法如下:

int fclose(
FILE *stream // 文件指针
);

关闭成功,返回 0,错误返回 EOF

有了上面这些知识,你就可以向文件写入一个 Hello World 了。其实还有很多内容,但是如标题所示,现在要写的是时间。是个字符串,只需要用到这些内容。其他的可参考 UCRT alphabetical function reference

获取时间:

现在来看看怎么获取当前时间。直接上代码,再说明函数语法(其实看注释就够了)。

#include <stdio.h>
#include <time.h> int main(void) {
char timebuf[21];// 字符串形式保存时间
time_t ltime;// 时间戳
struct tm today;// 本地时间结构体
errno_t err;// 错误码 time(&ltime);// 获取系统时间
err = _localtime64_s(&today, &ltime);// 转换为本地时间
if (err != 0) {
printf("无法转换为本地时间\n");
exit(1);
}
// 将时间转换为字符串,自定义格式
strftime(timebuf, 21, "%Y/%m/%d %T%n", &today);
printf(timebuf);
}

用到的函数有:time_localtime64_sstrftime

time 语法如下:

time_t time( time_t *destTime );	// 获取系统时间,参数是指向时间的存储位置的指针

返回值是从 1970/01/01 00:00:00 以来经过的秒数。有错误返回 -1

_localtime64_s 语法如下:

errno_t _localtime64_s(
struct tm* tmDest, // 指向要填充的时间结构体
__time64_t const* sourceTime // 指向时间的存储位置的指针
); // 将时间转换为本地时间结构体

转换成功返回 0,否则返回对应的错误码。

strftime 语法如下:

size_t strftime(
char *strDest, // 保存时间的字符串
size_t maxsize, // strDest指向的大小
const char *format, // 格式控制串,参照使用手册。
const struct tm *timeptr // 时间结构体
);

返回填充的字符数,如果超过了 maxsize,返回 0


到这里差不多就已经掌握了简单的写入时间操作。可以试试自己写一写。

不会也没关系,下面的代码是封装好的。可以直接调用。

函数原型:

// 功能:向txt文件filename末尾追加格式为YYYY/MM/DD HH:MM:SS的时间
// filename是文件名,文件名本身不带双引号
void log_time_filename(char const* filename);
// 功能:向stream指向的文件末尾追加格式为YYYY/MM/DD HH:MM:SS的时间
// stream必须打开
void log_time_stream(FILE* stream); // 参数是文件指针
// 功能:向txt文件filename末尾追加格式为YYYY/MM/DD HH:MM:SS的时间并换行
// filename是文件名,文件名本身不带双引号
void log_time_line_filename(char const* filename);
// 功能:向stream指向的文件末尾追加格式为YYYY/MM/DD HH:MM:SS的时间并换行
// stream必须打开
void log_time_line_stream(FILE* stream);

log.h文件:

将代码保存到与 调用文件 在同一级目录下的 log.h 文件中。有四个外部函数可供调用。

/*********************************************************************
文件: log.h
环境: Windows 10
IDE: Visual Studio 2019
版本: 1.5.0.1910
功能: 1、向 <文件名.txt> 文件末尾追加当前系统时间
2、向 <FILE* stream> 指向的文件末尾追加当前系统时间
备注: 1、目前只有默认日期格式,即YYYY/MM/DD hh:mm:ss
2、支持换行和不换行两种形式
日期: 2019年10月16日15:42:15
作者: wowpH
*********************************************************************/
#pragma once
#pragma message("log.h - wowpH - 1.5.0.1910") #include <stdio.h>
#include <stdlib.h>
#include <time.h> // 时间格式的最大长度
#define MAX_TIME_MODE_SIZE 21 //
// 可调用的函数
// // 通过文件名追加时间
void log_time_filename(char const* filename); // 通过文件指针追加时间
void log_time_stream(FILE* stream); // 通过文件名追加时间,换行
void log_time_line_filename(char const* filename); // 通过文件指针追加时间,换行
void log_time_line_stream(FILE* stream); //
// 供内部使用的函数,外部调用可能出错
// // 向strDest写入当前时间
void get_local_time(char* strDest); // 打开文件
void open_file(FILE** stream, char const* filename); // 关闭文件
void close_file(FILE* stream);

log.c文件:

将代码保存到与 调用文件 同一级目录下的 log.c 文件中。

#include "log.h"

const char* null_stream = "文件指针为空,请先打开一个文件!";
const char* error_open = "文件打开失败!";
const char* error_close = "文件关闭失败!";
const char* error_to_localtime = "无法转换为本地时间!"; void log_time_filename(char const* filename) {
FILE* stream = NULL;
open_file(&stream, filename);
log_time_stream(stream);
close_file(stream);
} void log_time_stream(FILE* const stream) {
if (stream != NULL) {
char time[MAX_TIME_MODE_SIZE];
get_local_time(time);
fprintf(stream, "%s", time);
} else {
printf("%s\n", null_stream);
exit(-1);
}
} void log_time_line_filename(char const* filename) {
FILE* stream = NULL;
open_file(&stream, filename);
log_time_line_stream(stream);
close_file(stream);
} void log_time_line_stream(FILE* stream) {
log_time_stream(stream);
fprintf(stream, "\n");
} static void get_local_time(char* strDest) {
time_t ltime;
time(&ltime);
struct tm today;
errno_t err;
err = _localtime64_s(&today, &ltime);
if (err != 0) {
printf("%s\n", error_to_localtime);
exit(-1);
}
// 将时间转换为字符串,自定义格式
strftime(strDest, MAX_TIME_MODE_SIZE, "%Y/%m/%d %T", &today);
} static void open_file(FILE** stream, char const* filename) {
errno_t err = 0;
err = fopen_s(stream, filename, "a");
if (err != 0) {
printf("%s\n", error_open);
exit(-1);
}
} static void close_file(FILE* stream) {
if (stream != NULL) {
errno_t err = 0;
err = fclose(stream);
if (err != 0) {
printf("%s\n", error_close);
exit(-1);
}
}
}

执行结果:

C语言向txt文件写入当前系统时间(Log)的更多相关文章

  1. java读取数据写入txt文件并将读取txt文件写入另外一个表

    package com.xsw.test; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.F ...

  2. Python统计字符出现次数(Counter包)以及txt文件写入

    # -*- coding: utf-8 -*- #spyder (python 3.7) 1. 统计字符(可以在jieba分词之后使用) from collections import Counter ...

  3. 5 个在 Linux 中管理文件类型和系统时间的有用命令

    对于想学习 Linux 的初学者来说要适应使用命令行或者终端可能非常困难.由于终端比图形用户界面程序更能帮助用户控制 Linux 系统,我们必须习惯在终端中运行命令.因此为了有效记忆 Linux 不同 ...

  4. php逐行读取txt文件写入数组的方法

    使用说明: 采用fopen 方法,逐行读取数据,并使用feof($fp)  判断是否文件截止,最后通过filter() 方法,去除空白行,得到所需数据 $file = fopen("user ...

  5. C# IO操作,写入文本到txt文件.

    /// <summary> /// 写入日志文件 /// </summary> /// <param name="input"></par ...

  6. Python 网络爬虫 010 (高级功能) 解析 robots.txt 文件

    解析 robots.txt 文件 使用的系统:Windows 10 64位 Python 语言版本:Python 2.7.10 V 使用的编程 Python 的集成开发环境:PyCharm 2016 ...

  7. Java文件写入与读取实例求最大子数组

    出现bug的点:输入数组无限大: 输入的整数,量大: 解决方案:向文件中输入随机数组,大小范围与量都可以控制. 源代码: import java.io.BufferedReader; import j ...

  8. TXT文件用法大全【荐】--------按键精灵

    来源:全文链接 (3)读取TXT文件指定某一行的第?到第?个字 UserVar t=2 "读出txt第几行文本" UserVar i=5 "从第几个字开始读取" ...

  9. linux OS与SQL修改时区,系统时间

    linux修改系统时间和linux查看时区.修改时区的方法 一.查看和修改Linux的时区 1. 查看当前时区命令 : "date -R" 2. 修改设置Linux服务器时区方法 ...

随机推荐

  1. 《JS权威指南学习总结--第7章 数组概念、稀疏数组》

    一.数组概念 数组是值的有序结合.每个值叫做一个元素,而每个元素在数组中都有一个位置,用数字表示,称为索引. JS数组是无类型的:数组元素可以是任意对象,并且同一个数组中的不同元素也可能有不同的类型. ...

  2. 一个判断js数据类型的函数

    function judgeType(change) { if (arguments.length == 0) { return '0';//无参数传入 } if (change === null) ...

  3. 配置WDA程序到NWBC

    NWBC是通过角色来做的权限管理,包括菜单项. 如果用户没有分配对应的,登陆后看到的东西很少,或者空白. 这里需要先将BC的个性化参数全部配齐,方便使用.BC最左上角,点击,设置,个性化设置. 如下几 ...

  4. java mybatis Column 'AAA' in where clause is ambiguous

    今天在java mybatis项目中遇到一个问题,“java mybatis Column 'AAA' in where clause is ambiguous”, 这是由于在多表连接查询的时候,遇上 ...

  5. 超快速度下载MNIST数据集

    Download mnist dataset and extract in 1 second! For Caffe users: create $CAFFE/data/mnist/get_mnist_ ...

  6. linux禁止root用户直接登录

    允许root用户登录是很不安全的,但是有时候为了测试的方便, 也可以允许root用户登录,但是这个方法最好不要对公网开放使用. 1.新建一个用户,用来登录 test@cloud:~> usera ...

  7. XGBoost 参数介绍

    XGBoost 的设置有三种参数:一般参数,提升参数和学习参数. 一般参数 取决于提升器,通常是树或线性模型提升参数 取决于选择的提升器的相关参数学习参数 取决于指定学习任务和相应的学习目标一般参数 ...

  8. 配置本地 yum 仓库

    配置本地 yum 仓库 # yum 官网 http://yum.baseurl.org/ # yum 手册页 man yum man yum.conf SEE ALSO pkcon (1) yum.c ...

  9. Pandas | 06 描述性统计

    有很多方法用来集体计算DataFrame的描述性统计信息和其他相关操作. 其中大多数是sum(),mean()等聚合函数. 一般来说,这些方法采用轴参数,就像ndarray.{sum,std,...} ...

  10. Babel7 转码

    ES6 (ES2015)更新了很多新的js语法, 也添加了一些新的API, 但不是所有的浏览器对这些新特性都支持的很好, 通过babel可以高版本的js转成低版本的js (ES 5.1), 同时对于J ...