C 取时间和写日志

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;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值