
公式不是问题,很简单,关键是你要设计你的表格。
你可以一个月一个EXCEL文件,这个文件有两个工作表,一个记录流水,有下面这些列:
A 日期
B 姓名
C 底衬
D 帮面
本表所有数据都是手工输入,每天记录。
另外一个表就是你这个月的工资汇总表,格式就是你给的样子:
A 姓名
B 底衬
C 帮面
D 工资
本表的姓名列是手工输入,其余各列使用公式:
B和C列的公式类似,使用SUMIF从流水表中汇总,比如B2的公式为:
=SUMIF(Sheet1!$B$2:$B$10000,A2,Sheet1!$C$2:$C$10000)
C2的公式为:
=SUMIF(Sheet1!$B$2:$B$10000,A2,Sheet1!$D$2:$D$10000)
D2的公式你会写吧,主要是知道底衬、帮面的单价,例如D2的公式为:
=B2894/330 + C2885/330
#include <stdioh>
#include <stdlibh>
#include <malloch>
#include <stringh>
#include <conioh>
#define TITLE "\n 月份 工号 姓名 应发工资 各种折扣 实发工资\n"
#define DATA " %2d %4ld %-10s %61f %61f %61f\n",p1->month,p1->num,p1->name,p1->should_pay,p1->rebate,p1->actual_pay
typedef struct pay
{
long num;
short month;
char name[20];
float gw,jn,zw,zl,jt,yj;
float should_pay;
float fz,gj,sd,others;
float rebate;
float actual_pay;
struct pay next;
}PAY;
FILE fp;
PAY p1=NULL,p2=NULL,head=NULL;
void menu();
PAY input();
void output();
void save(PAY head);
PAY open();
PAY insert();
void search();
PAY del();
PAY revise();
/主程序模块/
void main(void)
{
short sel;
do
{
menu();
scanf("%d",&sel);
switch(sel)
{
case 1:
head=input(); //输入模块
break;
case 2:
head=insert(); //插入模块
break;
case 3:
head=revise(); //修改模块
break;
case 4:
head=del(); //删除模块
break;
case 5:
search(); //查找模块
break;
case 6:
output(); //输出模块
break;
case 7:
save(head); //保存模块
break;
case 0:
break;
}
}while(sel!=0);
}
/菜单/
void menu()
{
printf("\n\n\n\n\n\n\n");
printf("\t\t\t\t 主菜单选项\n\n");
printf("\t\t\t\t1创建工资档案\n");
printf("\t\t\t\t2新增工资信息\n");
printf("\t\t\t\t3修改工资信息\n");
printf("\t\t\t\t4删除工资信息\n");
printf("\t\t\t\t5查找工资信息\n");
printf("\t\t\t\t6分类信息列表\n");
printf("\t\t\t\t7保 存 信 息\n");
printf("\t\t\t\t0退 出\n");
printf("\n\n\n\n\n\n\n\n");
}
/输入模块/
PAY input()
{
short n=1;
p1=(PAY)malloc(sizeof(PAY));
if(p1==NULL)
{
printf("内存不足,无法创建链表!");
getch();
}
printf("\n请输入第%d位职工的信息(以工号为0结束):\n",n);
printf(" 工号:");
scanf("%d",&p1->num);
if(p1->num==0)
{
printf("按任意键返回!");
getch();
free(p1);
return 0;
}
getchar();
printf(" 姓名:");
gets(p1->name);
printf(" 工资月份:");
scanf("%d",&p1->month);
printf(" 岗位工资,技能工资,职务津贴,职龄津贴,交通补贴,业绩津贴:\n");
scanf("%f,%f,%f,%f,%f,%f",&p1->gw,&p1->jn,&p1->zw,&p1->zl,&p1->jt,&p1->yj);
printf(" 房租扣款,公积金,水电费,其它扣款:\n");
scanf("%f,%f,%f,%f",&p1->fz,&p1->gj,&p1->sd,&p1->others);
p1->should_pay=p1->gw+p1->jn+p1->zw+p1->zl+p1->jt+p1->yj;
p1->rebate=p1->fz+p1->gj+p1->sd+p1->others;
p1->actual_pay=p1->should_pay-p1->rebate;
while(p1!=NULL)
{
if(n==1)
head=p1;
else
p2->next=p1;
n++;
p2=p1;
p1=(PAY)malloc(sizeof(PAY));
if(p1==NULL)
{
printf("内存不足,无法创建链表!");
getch();
}
printf("请输入第%d位职工的信息(以工号为0结束):\n",n);
printf(" 工号:");
scanf("%d",&p1->num);
getchar();
if(p1->num==0)
{
p1=NULL;
break;
}
printf(" 姓名:");
gets(p1->name);
printf(" 工资月份:");
scanf("%d",&p1->month);
printf(" 岗位工资,技能工资,职务津贴,职龄津贴,交通补贴,业绩津贴:\n");
scanf("%f,%f,%f,%f,%f,%f",&p1->gw,&p1->jn,&p1->zw,&p1->zl,&p1->jt,&p1->yj);
printf(" 房租扣款,公积金,水电费,其它扣款:\n");
scanf("%f,%f,%f,%f",&p1->fz,&p1->gj,&p1->sd,&p1->others);
p1->should_pay=p1->gw+p1->jn+p1->zw+p1->zl+p1->jt+p1->yj;
p1->rebate=p1->fz+p1->gj+p1->sd+p1->others;
p1->actual_pay=p1->should_pay-p1->rebate;
}
p2->next=NULL;
//edit by Yan-Xingyu Class Network-021
printf("职工信息已输入,请按任意键返回,并存盘……");
getch();
return head;
}
/输出模块/
void output()
{
short sel,flag,month;
float min,max;
do
{
do
{
printf("\n\n请选择您的列表方式:\n");
printf("\t\t1全部清单\n");
printf("\t\t2按月输出\n");
printf("\t\t3按工资段输出\n");
printf("\t\t0返回\n");
scanf("%d",&sel);
}while(sel!=1&&sel!=2&&sel!=3&&sel!=0);
head=open();
if(head==NULL)
return;
else
switch(sel)
{
case 1:
printf("\n\t\t\t 全部清单\n");
printf(TITLE);
p1=head;
do
{
printf(DATA);
p1=p1->next;
}while(p1!=NULL);
break;
case 2:
flag=0;
printf("输入要查的月份:");
scanf("%d",&month);
printf("\n\t\t\t第%d月工资清单\n",month);
printf(TITLE);
p1=head;
do
{
if(p1->month==month)
{
printf(DATA);
p1=p1->next;
flag=1;
}
else
p1=p1->next;
}while(p1!=NULL);
if(flag==0)
printf("没有该月清单\n");
break;
case 3:
flag=0;
printf("输入最低工资:");
scanf("%f",&min);
printf("输入最高工资:");
scanf("%f",&max);
printf("\n\t\t %51f到%51f工资的名单\n",min,max);
printf(TITLE);
p1=head;
do
{
if(p1->actual_pay>min&&p1->actual_pay<max)
{
printf(DATA);
p1=p1->next;
flag=1;
}
else
p1=p1->next;
}while(p1!=NULL);
if(flag==0)
printf("没有该工资段的职工\n");
break;
case 0:
break;
}
}while(sel!=0);
}
/保存文件/
void save(PAY head)
{
short write;
fp=fopen("paytxt","w");
if(fp==NULL)
{
printf("创建文件失败!");
getch();
return;
}
p1=p2=head;
while(p1!=NULL)
{
write=fwrite(p1,sizeof(PAY),1,fp);
if(!write)
{
printf("无法写入文件!");
getch();
return;
}
p1=p1->next;
}
fclose(fp);
printf("成功存盘!");
getch();
}
/打开文件/
PAY open()
{
short n=1,read;
fp=fopen("paytxt","r");
if(fp==NULL)
{
printf("无法打开档案文件!");
getch();
return NULL;
}
if((p1=p2=(PAY)malloc(sizeof(PAY)))==NULL)
{
printf("内存不足!");
getch();
return NULL;
}
read=fread(p1,sizeof(PAY),1,fp);
if(!read)
{
printf("文件读取出错!1");
getch();
return NULL;
}
if(p1->next==NULL)
head=p1;
else
{
do
{
if(n==1)
head=p1;
else
p2->next=p1;
n++;
p2=p1;
if((p1=(PAY)malloc(sizeof(PAY)))==NULL)
{
printf("内存不足!");
getch();
return NULL;
}
read=fread(p1,sizeof(PAY),1,fp);
if(!read)
{
printf("文件读取出错!2");
getch();
return NULL;
}
}while(p1->next!=NULL);
p2->next=p1;
}
return head;
fclose(fp);
}
/插入模块/
PAY insert()
{
PAY p3=NULL;
char sel;
head=open();
if(head==NULL)
return NULL;
else
do
{
printf("请输入要插入的职工信息:\n");
p3=(PAY)malloc(sizeof(PAY));
if(p3==NULL)
{
printf("内存不足,无法创建链表!");
getch();
}
printf(" 工号:");
scanf("%d",&p3->num);
getchar();
printf(" 姓名:");
gets(p3->name);
printf(" 工资月份:");
scanf("%d",&p3->month);
printf(" 岗位工资,技能工资,职务津贴,职龄津贴,交通补贴,业绩津贴:\n");
scanf("%f,%f,%f,%f,%f,%f",&p3->gw,&p3->jn,&p3->zw,&p3->zl,&p3->jt,&p3->yj);
printf(" 房租扣款,公积金,水电费,其它扣款:\n");
scanf("%f,%f,%f,%f",&p3->fz,&p3->gj,&p3->sd,&p3->others);
p3->should_pay=p3->gw+p3->jn+p3->zw+p3->zl+p3->jt+p3->yj;
p3->rebate=p3->fz+p3->gj+p3->sd+p3->others;
p3->actual_pay=p3->should_pay-p3->rebate;
p1=head;
while(p1!=NULL)
{
p2=p1;
p1=p1->next;
}
p2->next=p3;
p3->next=NULL;
printf("成功插入,是否继续?是(Y) 否(N)\n");
sel=getch();
}while(sel=='Y'||sel=='y');
printf("\n任意键返回,并存盘……\n");
getch();
return head;
}
/查找模块/
void search()
{
short sel;
long num;
char name[20],choose;
head=open();
if(head==NULL)
return;
else
do
{
do
{
printf("\n选择查找方式:\n");
printf("\t\t1按工号查找\n");
printf("\t\t2按姓名查找\n");
scanf("%d",&sel);
getchar();
}while(sel!=1&&sel!=2);
switch(sel)
{
case 1:
printf("输入要查的工号:");
scanf("%ld",&num);
break;
case 2:
printf("输入要查的姓名:");
gets(name);
break;
}
p1=head;
while((p1->next!=NULL)&&(p1->num!=num)&&(strcmp(p1->name,name)!=0)) //用成p1!=NULL有问题?
p1=p1->next;
if((p1->num==num)||strcmp(p1->name,name)==0)
{
printf("您要查找的信息如下:\n");
printf(TITLE);
printf(DATA);
}
else
printf("没有该信息!\n");
printf("是否继续?是(Y) 否(N)\n");
choose=getch();
}while(choose=='Y'||choose=='y');
printf("任意键返回");
getch();
}
/删除模块/
PAY del()
{
short sel;
long num;
char name[20],choose;
head=open();
if(head==NULL)
return NULL;
else
do
{
do
{
printf("\n选择删除方式:\n");
printf("\t\t1按工号删除\n");
printf("\t\t2按姓名删除\n");
scanf("%d",&sel);
getchar();
}while(sel!=1&&sel!=2);
switch(sel)
{
case 1:
printf("输入要删除的工号:");
scanf("%ld",&num);
break;
case 2:
printf("输入要删除的姓名:");
gets(name);
break;
}
p1=head;
if((p1->num==num)||strcmp(p1->name,name)==0)
{
head=p1->next;
printf("删除信息成功!");
}
else
{
while((p1->next!=NULL)&&(p1->num!=num)&&(strcmp(p1->name,name)!=0))
{
p2=p1;
p1=p1->next;
}
if((p1->num==num)||strcmp(p1->name,name)==0)
{
p2->next=p1->next;
free(p1);
printf("\n删除信息成功!\n");
}
else
printf("\n没有该信息!\n");
}
printf("是否继续?是(Y) 否(N)\n");
choose=getch();
}while(choose=='Y'||choose=='y');
printf("任意键返回,并存盘……");
getch();
return head;
}
/修改模块/
PAY revise()
{
short sel;
long num;
char name[20],choose;
head=open();
if(head==NULL)
return NULL;
else
do
{
do
{
printf("\n查找要修改的对象:\n");
printf("\t\t1按工号查找\n");
printf("\t\t2按姓名查找\n");
scanf("%d",&sel);
getchar();
}while(sel!=1&&sel!=2);
switch(sel)
{
case 1:
printf("输入要查的工号:");
scanf("%ld",&num);
break;
case 2:
printf("输入要查的姓名:");
gets(name);
break;
}
p1=head;
while((p1->next!=NULL)&&(p1->num!=num)&&(strcmp(p1->name,name)!=0)) //用成p1!=NULL有问题?
p1=p1->next;
if((p1->num==num)||strcmp(p1->name,name)==0)
{
printf("您要修改的原始信息如下:\n");
printf(TITLE);
printf(DATA);
printf("\n将上述信息改为如下信息:\n");
printf(" 工号:");
scanf("%d",&p1->num);
getchar();
printf(" 姓名:");
gets(p1->name);
printf(" 工资月份:");
scanf("%d",&p1->month);
printf(" 岗位工资,技能工资,职务津贴,职龄津贴,交通补贴,业绩津贴:\n");
scanf("%f,%f,%f,%f,%f,%f",&p1->gw,&p1->jn,&p1->zw,&p1->zl,&p1->jt,&p1->yj);
printf(" 房租扣款,公积金,水电费,其它扣款:\n");
scanf("%f,%f,%f,%f",&p1->fz,&p1->gj,&p1->sd,&p1->others);
p1->should_pay=p1->gw+p1->jn+p1->zw+p1->zl+p1->jt+p1->yj;
p1->rebate=p1->fz+p1->gj+p1->sd+p1->others;
p1->actual_pay=p1->should_pay-p1->rebate;
}
else
printf("你要修改的信息不存在!\n");
printf("是否继续?是(Y) 否(N)\n");
choose=getch();
}while(choose=='Y'||choose=='y');
printf("任意键返回,并存盘……");
getch();
return head;
}
EsSs:考勤和工资的编写代码用C#语言如何实现_百度知道
为获取建议,你需要提供有效的E-Mail地址
根据此需求
我们能提供一套与需求相适应的程序
您还能直接应用百度Hi联系我们
陆五柒幺伍六幺伍('幺'读yao,一声)
ES:\\aHR0cDovL3poaWRhby5iYWlkdS5jb20vcXVlc3Rpb24vMzQ1MzM2MTA1Lmh0bWw=
EsSs:考勤和工资的编写代码用C#语言如何实现_百度知道
交易提醒:预付订金是诈骗
能否提供银行转账代码,这不是银行进行查询打印的充分必要条件,能够提供代码,只能说银行工作人员可更快地直接查询,如果不能提供或是忘了,也不是必须企业提供才能查询,只要有相应的合规的手续,银行必须提供此项服务。可由公司财会人员去银行通过两种方式查询打印:一是可在智能设备上输入本公司账号,通过本公司在银行经授权的密码或预留在银行的认证方式予以查询打印,二是可在银行办理对公业务的人工柜面向工作人员出具本公司经签章(与在银行预留印鉴相符)的查询申请进行查询打印,银行有义务提供该服务。回过头来再说转账代码,可以在本公司委托银行代发工资时的相关凭证或其附件中找到,也可直接找银行查询,但这些工作量其实不如直接按上述方法去找银行解决最终的打印工资流水这个问题更小更简单,所以本人给出你直接去打印流水的方案。上面回答不知是否满意,请提宝贵意见,谢谢!祝好!
以上就是关于excel工资计算代码问题全部的内容,包括:excel工资计算代码问题、求C++编程的的工资管理系统源代码 小型的 交给老师的、考勤和工资的编写代码用C#语言如何实现等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)