excel中,知道入职日期和离职日期,怎么求一月在职人数?急求……

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了excel中,知道入职日期和离职日期,怎么求一月在职人数?急求……相关的知识,希望对你有一定的参考价值。

筛选
如计算3月份在职人数
在入职日期那一列选择3月1日前的,在离职日期那一列去掉3月31日前的,剩下的就是3月份在职人信息。一累计就出来了。
去年一年的在职人数是个随日期变化的离散数列,只有某个时间点是个固定的数。你可以算年初时在职人数,年终时在职人数,一年内新入职人数,一年内离职人数。
参考技术A 公式(用函数)
功能(用筛选)追问

不好意思,公式能写出来看看吗?还有一个问题,怎么查询去年在职人数?(最好是函数公式),谢了……

追答

=COUNTIF(离职日期所在列,2004-5-10")
单元格格式为常规,否则显示为日期

C语言中 求两个日期间的天数

想知道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中,知道入职日期和离职日期,怎么求一月在职人数?急求……的主要内容,如果未能解决你的问题,请参考以下文章

根据入职时间算工龄年月日

求根据入职日期计算工龄的公式,并附带解释。

怎样在EXCEL计算两个日期中间间隔几年几个月几天

SQL Server的四个查询语句,题目在内容里

求大神们解答 如何在Mysql 中 用出生日期来求几个人的平均年龄

根据出生年份计算年龄的公式,如何根据出生日期求年龄?