怎样用vb编写打印工资表程序

怎样用vb编写打印工资表程序,第1张

你先得建立一个人员工资数据库。编写VB *** 作数据库的程序。

打印程序代码的写法我几年前在Baidu知道中贴出过代码。

VB下数据报表打印输出方法有多种,一是通过自己的设计和编程完成报表打印输哪肢出。二是通过MS OFFICE实现报表打印输出。三是应用数据报表设计器的报表打印输出。本人经常使用第一种方法,它具有根据需要灵活应用的特点,烂喊但需编写程饥缓野序。

参见:http://zhidao.baidu.com/question/6426121.html

标准答案,放心使用!

#include<stdio.h>

#define NUM 100

void input()

void search()

void search_num()

void dele()

void dele_name()

void dele_num()

void modi()

void modi_num()

void output()

void stat()

void fun()

void run()

struct emploee /*职工数据结构*/

{

char no[5]

char name[8]

char sex[3]

int age

int salar

}emp[NUM],newemp

main()

{int x

printf("1. 输入职工记录\n")

printf("2. 查询职工记录\n")

printf("3. 修改职工记录\n")

printf("4. 删除职工记录\n")

printf("5. 打印职工记录\n")

printf("6. 调做蚂查工资情况\n")

printf("7. 追加职工记录\n")

printf("8. 结束使用\n")

printf("0. 退出系统\n")

printf("\n")

printf("*** 欢迎使用职工工资管理系统 ***\n")

printf("请选择(0-8):\n")

scanf("%d",&x)

switch(x)

{

case 1: input()break

case 2: search()break

case 3: modi()break

case 4: dele()break

case 5: output()break

case 6: stat()break

case 7: run()break

case 8: fun()break

default:printf("\n Wrong!")

}

if(x==0)break

}

}

void input()

{

FILE *fp

int n,i

if ((fp=fopen("emp","wb"))==NULL)

{

printf("不能建立emp文件唯胡御\n")

exit(1)

}

printf("输入职工人数:")

scanf("%d",&n)

printf("输入格式:职工号 姓名 性别 年龄 工资<Enter>\n")

for(i=0i<ni++) /* 循环获取n个职工记录 */

{

printf("第%d个职工:",i+1)

scanf("%s%s%s%d%d",emp[i].no,emp[i].name,emp[i].sex,

&emp[i].age,&emp[i].salar)

}

for(i=0i<ni++) /*将n个职工记录写入文件*/

fwrite(&emp[i],sizeof(struct emploee),1,fp)

fclose(fp)

}

/*************************统计模块**********************/

void stat( )

{

FILE *fp

int n,num

if((fp=fopen("emp","rb"))==NULL)

{

printf("不能打开指岩emp文件\n")

exit(1)

}

printf("工资数:")

scanf("%d",&num)

printf("记录号 职工号 姓名 性别 年龄 工资\n")

for(n=0fread(&emp,sizeof(struct emploee),1,fp)n++)

if(emp[n].salar>=num)

printf("%6d%6s%9s%4s%5d%6d\n",n+1,emp[n].no,emp[n].name,emp[n].sex,

emp[n].age,emp[n].salar)

fclose(fp)

}

/********************删除模块*******************/

void dele()

{

int x

while(1)

{

printf("\n\n\t\t删除子菜单\n")

printf("\t\t*********\n")

printf("\t\t 1.按职工号删除记录\n")

printf("\t\t 0.返回主菜单\n")

printf("\t\t*********\n")

printf("\t 请选择(0-1):")

scanf("%d",&x)

switch(x)

{case 1:dele_num()break

default:printf("\nWrong!")

}

if(x==0)break

}

}

void dele_num()

{

FILE *fp

int i,j,n

char num[5]

if((fp=fopen("emp","rb"))==NULL)

{

printf("不能打开emp文件\n")

exit(1)

}

printf("删除前:\n")

printf("记录号 职工号姓名 性别 年龄 工资\n")

for(n=0fread(&emp[n],sizeof(struct emploee),1,fp)n++)

printf("%6s%6s%9s%4s%5d%6d\n",n+1,emp[n].no,emp[n].name,emp[n].sex,

emp[n].age,emp[n].salar)/*n为emp文件中记录数*/

printf("要删除的职工号:")

scanf("%s",num)

for(i=0(strcmp(emp[i].no,num)!=0&&i<n)i++)

if(i>=n)

{

printf("\t没有%s职工号的职工\n",num)

exit(2)

}

fclose(fp)

fp=fopen("emp","w+")

if(n==1) /*一个记录已经删除了*/

{

fclose(fp)

exit(3)

}

for(j=0j<ij++)

fwrite(&emp[j],sizeof(struct emploee),1,fp)

for(j=i+1j<nj++)

fwrite(&emp[j],sizeof(struct emploee),1,fp)

printf("删除后:\n")

fseek(fp,0,SEEK_SET)

printf("记录号 职工号 姓名 性别 年龄 工资\n")

for(i=0fread(&emp[i],sizeof(struct emploee),1,fp)i++)

printf("%6s%6s%9s%4s%5d%6d\n",i+1,emp[i].no,emp[i].name,emp[i].sex,

emp[i].age,emp[i].salar)

fclose(fp)

}

/********************修改模块*******************/

void modi()

{

int x

while(1)

{

printf("\n\n\t\t修改子菜单\n")

printf("\t\t*********************\n")

printf("\t\t1. 按职工号修改\n")

printf("\t\t0. 返回主菜单\n")

printf("\t\t*********************\n")

printf("\t请选择(0-1):")

scanf("%d",&x)

switch(x)

{

case 1:modi_num()break

default:printf("\n输错误!")

}

if(x==0)break

}

}

void modi_num()

{

FILE *fp

int i,j

char num[5]

if((fp=fopen("emp","rb+"))==NULL)

{

printf("不能 打开emp文件\n")

exit(1)

}

printf("要修改的职工号:")

scanf("%s",num)

for(i=0fread(&emp[i],sizeof(struct emploee),1,fp)i++)

if(!strcmp(emp[i].no,num))break

if(feof(fp))

{

printf("\t没有%s职工号的职工\n",num)

exit(2)

}

printf("记录号 职工号 姓名 性别 年龄 工资\n")

printf("%6d%6s%9s%4s%5d%6d\n",i+1,emp[i].no,emp[i].name,emp[i].sex,

emp[i].age,emp[i].salar)

printf("输入格式:职工号 姓名 性别 年龄 工资<Enter>\n")

printf("第%d个记录:",i+1)

scanf("%s%s%s%d%d",newemp.no,newemp.name,newemp.sex,&newemp.age,

&newemp.salar)/*获取新的职工记录*/

fseek(fp,-(long)sizeof(struct emploee),SEEK_CUR)

/*文件指针指向该修改的记录开头*/

fwrite(&newemp,sizeof(struct emploee),1,fp)/*用newemp覆盖当前记录*/

printf(" 修改后:\n")

fseek(fp,0,SEEK_SET)/*显示修改后的文件数据*/

printf("记录号 职工号 姓名 性别 年龄 工资\n")

for(i=0fread(&emp[i],sizeof(struct emploee),1,fp)!=0i++)

printf("%6d%6s%9s%4s%5d%6d\n",i+1,emp[i].no,emp[i].name,emp[i].sex,

emp[i].age,emp[i].salar)

fclose(fp)

}

/*************************查询模块***********************/

void search( )

{

int x

while(1)

{

printf("\n\n\t\t查子菜单\n")

printf("\t\t********************\n")

printf("\t\t 1.按职工号查询\n")

printf("\t\t 0.返回主菜单\n")

printf("\t\t********************\n")

printf("\t请选择(0-1):")

scanf("%d",&x)

switch(x)

{

case 1:search_num()break

default :printf("\n Wrong!")

}

if(x==0) break

}

}

void search_num()

{

FILE *fp

int i

char num

if((fp=fopen("emp","rb"))==NULL)

{

printf("不能打开emp文件\n")

exit(1)

}

printf("要查询的职工号:")

scanf("%s",num)

for(i=0fread(&emp[i],sizeof(struct emploee),1,fp)i++)

if(!strcmp(emp[i].no,num)) break

if(feof(fp))

{

printf("\t查无此人\n")

exit(2)

}

printf("记录号 职工号 姓名 性别 年龄 工资\n")

printf("%6d%6s%9s%4s%5d%6d\n",i+1,emp[i].no,emp[i].name,emp[i].sex,

emp[i].age,emp[i].salar)

fclose(fp)

}

/*******************输出模块********************/

void output()

{int i

FILE *fp

if((fp=fopen("emp","r"))==NULL)

{printf("不能打开emp文件\n")

exit(0)

}

printf("记录号 职工号 姓名 性别 年龄 工资\n")

for(i=0fread(&emp[i],sizeof(struct emploee),1,fp)!=0i++)

{

printf("%6d%6s%9s%4s%5d%6d\n",i+1,emp[i].no,emp[i].name,emp[i].sex,

emp[i].age,emp[i].salar)

}

fclose(fp)

}

/******************追加模块*******************/

void run()

{

FILE *fp

int n,i,j

if((fp=fopen("emp","ab+"))==NULL)

{printf("不能打开emp文件\n")

exit(0)

}

printf("要追加的职工人数:")

scanf("%d",&n)

for(i=0i<ni++)

{ printf("输入格式:职工号 姓名 性别 年龄 工资<enter>\n")

printf("职工记录:")

scanf("%s%s%s%d%d",newemp.no,newemp.name,newemp.sex,&newemp.age,

&newemp.salar)

/*获取一个职工记录*/

fwrite(&newemp,sizeof(struct emploee),1,fp)

/*将该职工记录写入文件*/

}

fclose(fp)

}

/*******************显示模块****************/

void fun()

{printf("\t\t******************************************\n")

printf("\t\t* *\n")

printf("\t\t* *\n")

printf("\t\t* 谢 谢 使 用 ! *\n")

printf("\t\t* *\n")

printf("\t\t* *\n")

printf("\t\t******************************************\n")

}

工资表汇总常用excel功能

(1)插入辅助列  (2)排禅哪纤序

工资表转工资条的制作方法

第一步: 打开我们要处理的excel工资表

第贺仿二步:在工资表的后面一列填写序号(小技巧:在 G2填上1之后,把鼠标放在G1的左下角,出现一个+,点2次+,即可自动填充),在复制两次。

第三步:复制6次表头

第四步:排序,主要关键字以G列(就是我们加序号的那列),升序;次要关键字以F列(就是应发工资那列),点击确定。

壹缓厅人事HR提供最新最全的Excel工资表模板、工资表格式,欢迎下载和使用! 制作完Excel工资表后,发工资条的形式也是很多HR所苦恼的,如果每个月采用传统的发纸质工资条形式的话,那么对于人员众多的大型企业来说,这将是一个非常大的工作量,推荐壹人事工资条群发平台。

HR只需要上传Excel工资表,一键群发工资条,员工通过短信、邮件、微信都可以查看。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/12541904.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-26
下一篇 2023-05-26

发表评论

登录后才能评论

评论列表(0条)

保存