010_文件整理,employee文件中记录了工号和姓名

文件整理,employee文件中记录了工号和姓名

employee.txt:
100 Jason Smith 
200 John Doe 
300 Sanjay Gupta 
400 Ashok Sharma 

bonus文件中记录工号和工资

bonus.txt:
100 $5,000 
200 $500 
300 $3,000 
400 $1,250 

要求把两个文件合并并输出如下,处理结果:

100 Jason Smith      100 $5,000 
200 John Doe         200 $500 
300 Sanjay Gupta     300 $3,000
400 Ashok Sharma     400 $1,250 


Linux join命令用于将两个文件中,指定栏内容相同的行连接起来。
找出两个文件中,指定栏内容相同的行,并加以合并,再输出到标准输出设备。

#! /bin/bash

join employee.txt bonus.txt | sort -k 2


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的企业员工信息管理系统的 C 语言实现,具体实现细节可以根据需求进行修改和完善: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_EMPLOYEES 100 // 最大员工数量 #define MAX_NAME_LEN 20 // 姓名最大长度 #define MAX_WORK_LEN 30 // 工作最大长度 #define MAX_ADDR_LEN 50 // 地址最大长度 #define MAX_PHONE_LEN 15 // 电话最大长度 #define FILE_NAME "employees.dat" // 员工信息文件名 // 定义员工信息结构体 typedef struct { int id; // 工号 char name[MAX_NAME_LEN]; // 姓名 int age; // 年龄 char work[MAX_WORK_LEN]; // 工作 char sex[5]; // 性别 char addr[MAX_ADDR_LEN]; // 地址 char phone[MAX_PHONE_LEN]; // 电话 char start_date[20]; // 入职时间 } employee; // 函数声明 void print_menu(); void add_employee(employee *employees, int *count); void update_employee(employee *employees, int *count); void delete_employee(employee *employees, int *count); void query_employee(employee *employees, int count); void sort_employee(employee *employees, int count); void stats_employee(employee *employees, int count); void print_employee(employee emp); void print_all_employee(employee *employees, int count); void save_employees_to_file(employee *employees, int count); void load_employees_from_file(employee *employees, int *count); // 主函数 int main() { employee employees[MAX_EMPLOYEES]; // 员工数组 int count = 0; // 员工数量 load_employees_from_file(employees, &count); // 从文件读取员工信息 int choice = -1; // 用户选择菜单项 while (choice != 0) { print_menu(); // 打印菜单项 printf("请输入选项:"); scanf("%d", &choice); switch (choice) { case 1: add_employee(employees, &count); break; case 2: update_employee(employees, &count); break; case 3: delete_employee(employees, &count); break; case 4: query_employee(employees, count); break; case 5: sort_employee(employees, count); break; case 6: stats_employee(employees, count); break; case 7: print_all_employee(employees, count); break; case 0: save_employees_to_file(employees, count); // 将员工信息写入文件 printf("谢谢使用,再见!\n"); break; default: printf("无效选项,请重新输入!\n"); break; } } return 0; } // 打印菜单项 void print_menu() { printf("员工信息管理系统\n"); printf("1. 录入员工信息\n"); printf("2. 更新员工信息\n"); printf("3. 删除员工信息\n"); printf("4. 查询员工信息\n"); printf("5. 排列员工信息\n"); printf("6. 统计员工信息\n"); printf("7. 输出员工信息\n"); printf("0. 退出\n"); } // 录入员工信息 void add_employee(employee *employees, int *count) { if (*count >= MAX_EMPLOYEES) { printf("员工数量已达到上限,无法继续添加!\n"); return; } employee emp; printf("请输入员工信息:\n"); printf("工号:"); scanf("%d", &(emp.id)); printf("姓名:"); scanf("%s", emp.name); printf("年龄:"); scanf("%d", &(emp.age)); printf("工作:"); scanf("%s", emp.work); printf("性别:"); scanf("%s", emp.sex); printf("地址:"); scanf("%s", emp.addr); printf("电话:"); scanf("%s", emp.phone); printf("入职时间:"); scanf("%s", emp.start_date); employees[*count] = emp; (*count)++; printf("员工信息已添加!\n"); } // 更新员工信息 void update_employee(employee *employees, int *count) { int id; printf("请输入要修改的员工工号:"); scanf("%d", &id); for (int i = 0; i < *count; i++) { if (employees[i].id == id) { employee emp; printf("请输入新的员工信息:\n"); printf("姓名:"); scanf("%s", emp.name); printf("年龄:"); scanf("%d", &(emp.age)); printf("工作:"); scanf("%s", emp.work); printf("性别:"); scanf("%s", emp.sex); printf("地址:"); scanf("%s", emp.addr); printf("电话:"); scanf("%s", emp.phone); printf("入职时间:"); scanf("%s", emp.start_date); employees[i] = emp; printf("员工信息已修改!\n"); return; } } printf("未找到工号为 %d 的员工信息!\n", id); } // 删除员工信息 void delete_employee(employee *employees, int *count) { int id; printf("请输入要删除的员工工号:"); scanf("%d", &id); for (int i = 0; i < *count; i++) { if (employees[i].id == id) { for (int j = i; j < *count - 1; j++) { employees[j] = employees[j + 1]; } (*count)--; printf("员工信息已删除!\n"); return; } } printf("未找到工号为 %d 的员工信息!\n", id); } // 查询员工信息 void query_employee(employee *employees, int count) { int choice; printf("请选择查询方式:\n"); printf("1. 按姓名查询\n"); printf("2. 按年龄查询\n"); printf("3. 按工作查询\n"); printf("请输入选项:"); scanf("%d", &choice); switch (choice) { case 1: char name[MAX_NAME_LEN]; printf("请输入员工姓名:"); scanf("%s", name); for (int i = 0; i < count; i++) { if (strcmp(employees[i].name, name) == 0) { print_employee(employees[i]); } } break; case 2: int min_age, max_age; printf("请输入员工年龄范围(最小年龄 最大年龄):"); scanf("%d %d", &min_age, &max_age); for (int i = 0; i < count; i++) { if (employees[i].age >= min_age && employees[i].age <= max_age) { print_employee(employees[i]); } } break; case 3: char work[MAX_WORK_LEN]; printf("请输入员工工作:"); scanf("%s", work); for (int i = 0; i < count; i++) { if (strcmp(employees[i].work, work) == 0) { print_employee(employees[i]); } } break; default: printf("无效选项,请重新输入!\n"); break; } } // 排列员工信息 void sort_employee(employee *employees, int count) { for (int i = 0; i < count - 1; i++) { for (int j = 0; j < count - i - 1; j++) { if (employees[j].age > employees[j + 1].age) { employee temp = employees[j]; employees[j] = employees[j + 1]; employees[j + 1] = temp; } } } printf("员工信息已排列!\n"); } // 统计员工信息 void stats_employee(employee *employees, int count) { int age, sex; char work[MAX_WORK_LEN]; printf("请输入员工信息统计条件:\n"); printf("年龄(-1 表示不限):"); scanf("%d", &age); printf("性别(0 表示女,1 表示男,-1 表示不限):"); scanf("%d", &sex); printf("工作(空格表示不限):"); scanf("%s", work); int total = 0; for (int i = 0; i < count; i++) { if ((age == -1 || employees[i].age == age) && (sex == -1 || strcmp(employees[i].sex, sex == 0 ? "女" : "男") == 0) && (strcmp(work, "") == 0 || strcmp(employees[i].work, work) == 0)) { total++; } } printf("符合条件的员工数量为:%d\n", total); } // 输出单个员工信息 void print_employee(employee emp) { printf("工号:%d,姓名:%s,年龄:%d,工作:%s,性别:%s,地址:%s,电话:%s,入职时间:%s\n", emp.id, emp.name, emp.age, emp.work, emp.sex, emp.addr, emp.phone, emp.start_date); } // 输出所有员工信息 void print_all_employee(employee *employees, int count) { for (int i = 0; i < count; i++) { print_employee(employees[i]); } } // 将员工信息写入文件 void save_employees_to_file(employee *employees, int count) { FILE *fp = fopen(FILE_NAME, "wb"); if (fp == NULL) { printf("文件打开失败!\n"); return; } fwrite(&count, sizeof(int), 1, fp); fwrite(employees, sizeof(employee), count, fp); fclose(fp); printf("员工信息已保存到文件!\n"); } // 从文件读取员工信息 void load_employees_from_file(employee *employees, int *count) { FILE *fp = fopen(FILE_NAME, "rb"); if (fp == NULL) { printf("文件打开失败!\n"); return; } fread(count, sizeof(int), 1, fp); fread(employees, sizeof(employee), *count, fp); fclose(fp); printf("已加载员工信息文件!\n"); } ``` 注意事项: - 为了方便管理,我们将员工信息保存在一个文件(`employees.dat`),程序启动时会从文件读取员工信息,程序退出时会将员工信息写入文件。 - 由于使用了结构体数组来保存员工信息,因此需要传递指向员工数组的指针和当前员工数量的指针。 - 在查询员工信息时,我们提供了三种查询方式:按姓名查询、按年龄查询、按工作查询。其,按年龄查询时用户需要输入年龄范围,按性别查询时用户需要输入 0 表示女、1 表示男、-1 表示不限。 - 在统计员工信息时,用户需要输入统计条件,包括年龄、性别、工作,其年龄和性别可以输入 -1 表示不限,工作可以输入空格表示不限。 - 在保存员工信息文件时,我们先将员工数量写入文件,然后再将员工数组写入文件。在读取员工信息时,我们先读取员工数量,然后再读取员工数组。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值