excel中,知道入职日期和离职日期,怎么求一月在职人数?急求……
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了excel中,知道入职日期和离职日期,怎么求一月在职人数?急求……相关的知识,希望对你有一定的参考价值。
筛选如计算3月份在职人数
在入职日期那一列选择3月1日前的,在离职日期那一列去掉3月31日前的,剩下的就是3月份在职人信息。一累计就出来了。
去年一年的在职人数是个随日期变化的离散数列,只有某个时间点是个固定的数。你可以算年初时在职人数,年终时在职人数,一年内新入职人数,一年内离职人数。 参考技术A 公式(用函数)
功能(用筛选)追问
不好意思,公式能写出来看看吗?还有一个问题,怎么查询去年在职人数?(最好是函数公式),谢了……
追答=COUNTIF(离职日期所在列,2004-5-10")
单元格格式为常规,否则显示为日期
C语言中 求两个日期间的天数
想知道C语言中是否提供这样的函数,求出两个日期之间的天数?
如果没有现成的函数能用,想知道如何写代码实现这个功能?
请赐教,谢谢。
这怎么能直接相减 ,年份要判断一下吧,月份也要判断吧
要把年、月、日分开来求...
#include <stdio.h>
int mon[12]=31,28,31,30,31,30,31,31,30,31,30,31; /*储存12个月的天数*/
void main()
int spec_year(int);
void scan(int *year,int *month,int *day);
long com_year(int y1,int y2);
int com_month(int y1,int m1,int y2,int m2);
int com_day(int y1,int m1,int d1,int y2,int m2,int d2);
int year1,month1,day1;
int year2,month2,day2;
long sum=0;
int k=0;
/*输入两个日期,做合法性检查*/
printf("Enter the first date,like 1988 11 30:");
scan(&year1,&month1,&day1);
printf("Enter the second date,like 1988 11 30:");
scan(&year2,&month2,&day2);
/*当输入的第一个日期比第二个日期大时,将二者对换*/
if((year1>year2)||((year1==year2)&&(month1>month2))||((year1==year2)&&(month1==month2)&&(day1>day2)))
int temp;
temp=year1;year1=year2;year2=temp;
temp=month1;month1=month2;month2=temp;
temp=day1;day1=day2;day2=temp;
/*计算两个日期之间的天数*/
sum+=com_year(year1,year2); /*计算两个年份之间的天数*/
sum+=com_month(year1,month1,year2,month2); /*计算两个月份之间的天数*/
sum+=com_day(year1,month1,day1,year2,month2,day2); /*计算两天之间的天数*/
/*输出*/
printf("There are %ld days between them.\n",sum);
void scan(int *year,int *month,int *day) /*输入日期函数,合法性判断*/
int k=0;
do
if(k!=0)
printf("\nWrong date!\n");
k++;
/*printf("Please write down the day,like 1988 11 30:");*/
scanf("%d%d%d",year,month,day);
if(spec_year(*year))
mon[1]=29;
while(*day>mon[*month-1]||*month>13||*year<1900||*year>3000);
mon[1]=28;
long com_year(int y1,int y2) /*计算两个年份之间的天数*/
int i;
long sum=0;
for(i=y1+1;i<y2;i++)
if(spec_year(i))
sum+=366;
else
sum+=365;
return sum;
int com_month(int y1,int m1,int y2,int m2) /*计算两个月份之间的天数*/
int i;
int sum=0;
if(y1!=y2)
if(spec_year(y1))
mon[1]=29;
if(m1!=m2)
for(i=m1;i<12;i++)
sum+=mon[i];
mon[1]=28;
if(spec_year(y2))
mon[1]=29;
for(i=0;i<m2-1;i++)
sum+=mon[i];
mon[1]=28;
else
for(i=m1-1;i<12;i++)
sum+=mon[i];
mon[1]=28;
if(spec_year(y2))
mon[1]=29;
for(i=0;i<m2-1;i++)
sum+=mon[i];
mon[1]=28;
else
if(spec_year(y1))
mon[1]=29;
for(i=m1;i<m2-1;i++)
sum+=mon[i];
mon[1]=28;
return sum;
int com_day(int y1,int m1,int d1,int y2,int m2,int d2) /*计算两天之间的天数*/
int i;
int sum=0;
if(m1!=m2)
if(spec_year(y1))
mon[1]=29;
sum+=(mon[m1-1]-d1);
sum+=d2;
mon[1]=28;
else
sum+=d2-d1;
return sum;
int spec_year(int year) /*判断是否为闰年*/
if((year%400==0)||((year%4==0)&&(year%100!=0)))
return 1;
else
return 0;
参考技术A 不记得有类似的库函数,应该相减就能出结果。如果返回值不是 int 型就加个强制类型转换,应该很容易。
呵呵,我记错了。抱歉。C 语言没有日期变量。
这样的话,就八仙过海,各显其能了。楼下已经给出不少代码了,我就不现丑了。
以上是关于excel中,知道入职日期和离职日期,怎么求一月在职人数?急求……的主要内容,如果未能解决你的问题,请参考以下文章