免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2291 | 回复: 3
打印 上一主题 下一主题

关于时间操作的一些简单实现 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-07-25 20:25 |只看该作者 |倒序浏览
本帖最后由 浪子雄心 于 2011-05-07 21:13 编辑

/*
**
** 文件: time.c
**
** 功    能:关于时间操作的一些简单实现
**
** 编译及运行:
** $cc -o time  -g -Wall time.c
** $./time
**
**
** 作  者:没版权,随便用
**
** 说明:本函数功能可以自由拷贝使用,
**      可能存在没有发现在的Bug,
**      如有缺陷,还需使用者自行调试
*/

#include<stdio.h>
#include<stdlib.h>
#include<ctype.h>
#include<string.h>
#include<time.h>




/*
** 功能说明:得到指定日期的后一天
** 输入参数:struct tm *p
** 输出参数:int
** 返回值说明:0- 成功
*/
int getNextDay(struct tm *p){
        time_t timep;
        p->tm_sec=0;
        p->tm_min=0;
        p->tm_hour=0;
        timep = mktime(p)+24*60*60;
        p=localtime(&timep);
        return 0;
}


/*
** 功能说明:是否为闰年
** 输入参数:struct tm *p
** 输出参数:int
** 返回值说明:1-是  0- 否
*/
int isLeapYear(struct tm *p)
{
  return ((1900+p->tm_year) & 3) == 0 && ((1900+p->tm_year)%100 || \
          ((1900+p->tm_year)%400 == 0 && (1900+p->tm_year))) ?1 : 0;
}



/*
** 功能说明:是否为年未
** 输入参数:struct tm *p
** 输出参数:int
** 返回值说明:1- 是  0- 否
*/
int isYearEnd(struct tm *p){
        if( (11==p->tm_mon)&&(31== p->tm_mday)){
                return 1;
        }else{
                return 0;
        }
}



/*
** 功能说明:是否为月未
** 输入参数:struct tm *p
** 输出参数:int
** 返回值说明:1- 是  0- 否
*/
int isMonthEnd(struct tm *p){
        int Mday[]={31,28,31,30,31,30,31,31,30,31,30,31};

        if(1== p->tm_mon){
                Mday[p->tm_mon] += isLeapYear(p);
        }
        if(        p->tm_mday ==  Mday[p->tm_mon]){
                return 1;
        }else{
                return 0;
        }
}


/*
** 功能说明:是否是周未(周六与周日)
** 输入参数:struct tm *p
** 输出参数:int
** 返回值说明:1- 是  0- 否
*/
int isWeekEnd(struct tm *p){
        return((0==p->tm_wday)||(6==p->tm_wday))?1:0;
}


/*
** 功能说明:从一个时间字符串 YYMMDD, YYYYMMDD,  
**                         YYYYMMDDHHMMSS,YY-MM-DD, YYYY-MM-DD,
**                        YY-MM-DD HH.MM.SS 
**                        找到对应的日期并转为 struct tm 结构
** 输入参数:char *pos, struct tm *p
** 输出参数:int
** 返回值说明:0 -成功  -1 -日期识别出错
*/
int find_date(char *pos, struct tm *p)
{
        int Mday[]={31,28,31,30,31,30,31,31,30,31,30,31};
        int length,value,vek[4];
        int flag=1*4+2*16;
        char *start,*k;
        k=pos;
        bzero((char*) vek,sizeof(int)*4);

        while (*pos && !isdigit(*pos))
                pos++;
        length=(int) strlen(pos);
        int i=0;
        for (i=0 ; i< 3; i++)
        {
                start=pos; value=0;
                while (isdigit(pos[0]) &&
                        ((pos-start) < 2 || ((pos-start) < 4 && length >= 8 &&
                                                                !(flag & 3))))
                {
                        value=value*10 + (int) (char) (*pos - '0');
                        pos++;
                }
                vek[flag & 3]=value; flag>>=2;
                while (*pos && (ispunct(*pos) || isspace(*pos)))
                        pos++;
        }

        char tmp[8];
        bzero(tmp,sizeof(tmp));
        sprintf(tmp,"%d",vek[0]);


        if ((4 > strlen(tmp))&&(vek[0] < 70)){
                vek[0]+= 2000;
        }else if(4 != strlen(tmp)){
        vek[0]+= 1900;
        }

        p->tm_year=vek[0]-1900;
        p->tm_mon=vek[1]-1;
        p->tm_mday=vek[2];
        p->tm_sec=0;
        p->tm_min=0;
        p->tm_hour=0;

        if( 0>vek[0] || vek[0]>9999){
                printf("time str: [%s]  Year err!\n",k);
                return -1;
        }

        if( 0>vek[1] || vek[1]>12){
                printf("time str: [%s]  Month [%d] err!\n",k ,vek[1]);
                return -1;
        }


        Mday[1]+=isLeapYear(p);

        if( 0>vek[2] || vek[2]>Mday[vek[1]-1]){
                printf("time str: [%s]  Day [%d] err!\n",k , vek[2]);
                return -1;
        }


        return 0;
}






int test(char *sTime){

        printf("\n");
        struct tm *p;
        time_t timep;
        time(&timep);
        p=localtime(&timep);
        printf(" 当前日期 [%04d%02d%02d] \n", \
                (1900+p->tm_year),( 1+p->tm_mon), p->tm_mday);

        printf("被识别串为 [%s]\n",sTime);

        if(0 != find_date(sTime, p)){
                exit(0);
        };

        printf("日期识别为 [%04d%02d%02d]\n",1900+p->tm_year,1+p->tm_mon,p->tm_mday);
        getNextDay(p);
        printf("第二天日期 [%04d%02d%02d]\n",1900+p->tm_year,1+p->tm_mon,p->tm_mday);
        printf("是否为闰年 isLeapYear[%d]\n", isLeapYear(p));
        printf("是否是周末 isWeekend[%d] %d\n", p->tm_wday,isWeekEnd(p));

        printf("是否是月末 isMonthend[%04d%02d%02d] %d\n", \
                1900+p->tm_year,1+p->tm_mon,p->tm_mday, isMonthEnd(p));

        printf("是否是年末 isYearend[%04d%02d%02d] %d\n", \
                1900+p->tm_year,1+p->tm_mon,p->tm_mday, isYearEnd(p));
       
        printf("\n");

        return 0;
}






int main(){
/*
识别格式
YYMMDD,
YYYYMMDD,
YYYYMMDDHHMMSS,
YY-MM-DD,
YYYY-MM-DD,
YY-MM-DD HH.MM.SS
*/
        test("040528");
        test("20051230  12:21:12");
        test("20060227122112");
        test("06-02-28");
        test("2006-12-31");
        test("06-07-22 12.34.56");
        test("06-07-30 12.34.56");
        return 0;
}

[ 本帖最后由 浪子雄心 于 2006-7-26 16:47 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2006-07-26 16:34 |只看该作者
不错的例子,学习下

论坛徽章:
0
3 [报告]
发表于 2006-07-27 09:45 |只看该作者
不错的东东。。。。
thanks for your shared...

论坛徽章:
0
4 [报告]
发表于 2007-06-01 19:44 |只看该作者
静静的走过。。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP