博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C 取时间和写日志
阅读量:3588 次
发布时间:2019-05-20

本文共 4492 字,大约阅读时间需要 14 分钟。

logFile.h

--------------------------------------------

#ifndef _LOG_FILE_H_

#define _LOG_FILE_H_
#include "define.h"
void what_datetime(int *daytime);
void what_datetime_str(const char *fmt, char *datetime_str);
int log_printf(const char *format, ... );
char g_log_file_name[255];
#endif/*!_LOG_FILE_H_*/

---------------------------------------------------------------------

logFile.c

#include <stdlib.h>

#include <stdio.h>
#include <stdarg.h>
#include <string.h>
#include <time.h>
#include "LogFile.h"
/********************************************************************************
取系统时间
********************************************************************************/
void what_datetime(int *daytime)
{
int year, month, day, hour, min, sec;
time_t now;
struct tm *today;
time(&now);
today=localtime(&now);
daytime[0] = year = today->tm_year+1900;
daytime[1] = month = today->tm_mon+1;
daytime[2] = day = today->tm_mday;
daytime[3] = hour = today->tm_hour;
daytime[4] = min = today->tm_min;
daytime[5] = sec = today->tm_sec;
}
/***
   取昨天日期+当前系统时间
   Author: peidw
   Date  : 2010-10-09
**/
void what_yesterday_datetime(int *daytime)
{
int year, month, day, hour, min, sec;
time_t yesterday_t;
struct tm *yesterday;
yesterday_t = time(NULL) - 24 *60*60;
yesterday = localtime(&yesterday_t);
daytime[0] = year = yesterday->tm_year+1900;
daytime[1] = month = yesterday->tm_mon+1;
daytime[2] = day = yesterday->tm_mday;
daytime[3] = hour = yesterday->tm_hour;
daytime[4] = min = yesterday->tm_min;
daytime[5] = sec = yesterday->tm_sec;
}
/*****************************************************************
按fmt格式返回昨天的日期+当前系统时间
Author : peidw 
Date   : 2010-10-09
fmt:"mm/dd/yyyy"
"yyyy/mm/dd"
"yyyymmdd"
*****************************************************************/
void what_yesterday_datetime_str(const char *fmt, char *datetime_str)
{
char
buf[60];
int
datetime[6];
what_yesterday_datetime(datetime);
if (!strcmp(fmt, "mm/dd/yyyy") || !strcmp(fmt, "MM/DD/YYYY"))
sprintf(buf, "%02d/%02d/%04d", datetime[1], datetime[2], datetime[0]);
else if (!strcmp(fmt, "yyyymmdd") || !strcmp(fmt, "YYYYMMDD"))
sprintf(buf, "%04d%02d%02d", datetime[0], datetime[1], datetime[2]);
else if (!strcmp(fmt, "yyyy/mm/dd") || !strcmp(fmt, "YYYY/MM/DD"))
sprintf(buf, "%04d/%02d/%02d", datetime[0], datetime[1], datetime[2]);
else if (!strcmp(fmt, "yyyy/mm/dd hh:mm:ss") || !strcmp(fmt, "YYYY/MM/DD HH:MM:SS"))
sprintf(buf, "%04d/%02d/%02d %02d:%02d:%02d",
datetime[0], datetime[1], datetime[2],
datetime[3], datetime[4], datetime[5]);
else if (!strcmp(fmt, "hh:mm:ss") || !strcmp(fmt, "HH:MM:SS"))
sprintf(buf, "%02d:%02d:%02d",
datetime[3], datetime[4], datetime[5]);
strcpy(datetime_str, buf);
}
/*****************************************************************
fmt:"mm/dd/yyyy"
"yyyy/mm/dd"
"yyyymmdd"
*****************************************************************/
void what_datetime_str(const char *fmt, char *datetime_str)
{
char
buf[60];
int
datetime[6];
what_datetime(datetime);
if (!strcmp(fmt, "mm/dd/yyyy") || !strcmp(fmt, "MM/DD/YYYY"))
sprintf(buf, "%02d/%02d/%04d", datetime[1], datetime[2], datetime[0]);
else if (!strcmp(fmt, "yyyymmdd") || !strcmp(fmt, "YYYYMMDD"))
sprintf(buf, "%04d%02d%02d", datetime[0], datetime[1], datetime[2]);
else if (!strcmp(fmt, "yyyy/mm/dd") || !strcmp(fmt, "YYYY/MM/DD"))
sprintf(buf, "%04d/%02d/%02d", datetime[0], datetime[1], datetime[2]);
else if (!strcmp(fmt, "yyyy/mm/dd hh:mm:ss") || !strcmp(fmt, "YYYY/MM/DD HH:MM:SS"))
sprintf(buf, "%04d/%02d/%02d %02d:%02d:%02d",
datetime[0], datetime[1], datetime[2],
datetime[3], datetime[4], datetime[5]);
else if (!strcmp(fmt, "hh:mm:ss") || !strcmp(fmt, "HH:MM:SS"))
sprintf(buf, "%02d:%02d:%02d",
datetime[3], datetime[4], datetime[5]);
strcpy(datetime_str, buf);
}
/****************************************************************************
int logprintf(const char *format, ... )
用途:往logfile文件中写日志
****************************************************************************/
int log_printf(const char *format, ... )
{
va_list
ap;
FILE
*fp;
char
buf[4096];
int
ret;
char
time[256];
char
tday[256];
char
t_file_name[256];
what_datetime_str("yyyymmdd", tday);
sprintf(t_file_name,"%s%s_%s","logs/",g_log_file_name,tday);//2010-09-17 裴德万加上logs子目录
fp=fopen(t_file_name, "a");
if (fp == NULL)
return -1;
va_start(ap ,format);
vsprintf(buf, format, ap);
va_end(ap);
what_datetime_str("yyyy/mm/dd hh:mm:ss", time);
ret = fprintf(fp, "[%s] %s", time, buf);
fprintf(stdout, "[%s] %s", time, buf);
fclose(fp);
return ret;
}

转载地址:http://amvwn.baihongyu.com/

你可能感兴趣的文章
Raspberry Pi 3B+ 修改root初始密码,root登录
查看>>
PBRNet:Progressive Boundary Refinement Network for Temporal Action Detection (AAAI 2020)
查看>>
TypeError: create_target_machine() got an unexpected keyword argument ‘jitdebug‘解决方案
查看>>
FairMOT: On the Fairness of Detection and Re-Identification in Multiple Object Tracking 效果展示
查看>>
数据结构与算法-python实现堆栈,队列
查看>>
数据结构与算法-python实现无序表(单链表)
查看>>
数据结构与算法-python实现顺序表
查看>>
Django REST framework仅需几步完成搭建api
查看>>
Django REST framework 中的权限认证
查看>>
采用实例演示Vue生命周期
查看>>
idea破解后无法打开的解决办法
查看>>
浅谈js中节点的浅拷贝和深拷贝
查看>>
服务器tomcat成功运行但是无法在外网访问的解决办法
查看>>
排序算法的稳定问题
查看>>
M1安装环境
查看>>
类加载之双亲委派
查看>>
c++ make_pair&pair
查看>>
C++ mutable
查看>>
剑指offer:面试题18. 删除链表的节点
查看>>
剑指offer:面试题19. 正则表达式匹配
查看>>