14.职工信息查询程序 功能要求: 设计职工类,职工信息包括职工号、姓名、性别、年龄、学历、工资、住址、电话等 (自定义)(职工号不重复)。编写一个Java应用程序,实现职工信息从文件staf f.txt读取并通过姓名、工号查找指定职工信息。

时间: 2023-12-06 15:04:31 浏览: 231
好的,根据您的要求,我可以给您提供一个简单的职工信息查询程序的实现思路: 1. 定义职工类,包括职工号、姓名、性别、年龄、学历、工资、住址、电话等属性。可以使用构造方法和getter/setter方法对职工信息进行初始化和获取。 2. 定义一个职工管理类,用于实现职工信息的读取和查询。在职工管理类中,可以使用HashMap来存储职工信息,其中职工号作为键,职工对象作为值。 3. 在职工管理类中,编写一个方法用于从文件staff.txt中读取职工信息并将其存储到HashMap中。读取文件可以使用Java中的File和Scanner类。 4. 在职工管理类中,编写一个方法用于通过姓名或职工号来查询指定职工的信息。可以使用HashMap的get方法来获取指定的职工对象。 5. 在主函数中,创建职工管理对象,并调用读取职工信息和查询职工信息的方法,实现职工信息的查询。 以上是一个简单的职工信息查询程序的实现思路,您可以根据需求进行具体的实现。
相关问题

用java写一个职工信息查询程序 功能要求: 设计职工类,职工信息包括职工号、姓名、性别、年龄、学历、工资、住址、电话等(自定义)(职工号不重复)。编写一个Java应用程序,实现职工信息从文件staff.txt读取并通过姓名、工号查找指定职工信息。

好的,我可以给您提供一个简单的职工信息查询程序的Java代码示例,您可以参考。首先,我们需要先创建一个职工类Worker: ```java public class Worker { private String workerNo; // 职工号 private String name; // 姓名 private String gender; // 性别 private int age; // 年龄 private String education; // 学历 private double salary; // 工资 private String address; // 住址 private String phone; // 电话 // 构造函数 public Worker(String workerNo, String name, String gender, int age, String education, double salary, String address, String phone) { this.workerNo = workerNo; this.name = name; this.gender = gender; this.age = age; this.education = education; this.salary = salary; this.address = address; this.phone = phone; } // getter和setter方法 public String getWorkerNo() { return workerNo; } public void setWorkerNo(String workerNo) { this.workerNo = workerNo; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getEducation() { return education; } public void setEducation(String education) { this.education = education; } public double getSalary() { return salary; } public void setSalary(double salary) { this.salary = salary; } public String getAddress() { return address; } public void setAddress(String address) { this.address = address; } public String getPhone() { return phone; } public void setPhone(String phone) { this.phone = phone; } } ``` 然后,我们需要创建一个工具类来读取staff.txt文件中的职工信息,并将其存储到一个Worker对象的列表中: ```java import java.io.BufferedReader; import java.io.FileReader; import java.util.ArrayList; import java.util.List; public class WorkerUtil { // 从文件中读取职工信息并存储到列表中 public static List<Worker> readWorkersFromFile(String filePath) { List<Worker> workers = new ArrayList<>(); try (BufferedReader reader = new BufferedReader(new FileReader(filePath))) { String line; while ((line = reader.readLine()) != null) { String[] fields = line.split(","); if (fields.length != 8) { continue; } String workerNo = fields[0]; String name = fields[1]; String gender = fields[2]; int age = Integer.parseInt(fields[3]); String education = fields[4]; double salary = Double.parseDouble(fields[5]); String address = fields[6]; String phone = fields[7]; Worker worker = new Worker(workerNo, name, gender, age, education, salary, address, phone); workers.add(worker); } } catch (Exception e) { e.printStackTrace(); } return workers; } } ``` 接着,我们需要创建一个主程序类来实现职工信息查询功能: ```java import java.util.List; import java.util.Scanner; public class Main { public static void main(String[] args) { // 从文件中读取职工信息 List<Worker> workers = WorkerUtil.readWorkersFromFile("staff.txt"); Scanner scanner = new Scanner(System.in); while (true) { System.out.println("请输入查询方式(1:按姓名查询,2:按职工号查询,0:退出):"); int option = scanner.nextInt(); if (option == 0) { break; } if (option == 1) { System.out.println("请输入姓名:"); String name = scanner.next(); boolean found = false; for (Worker worker : workers) { if (worker.getName().equals(name)) { found = true; System.out.println(worker.getWorkerNo() + "," + worker.getName() + "," + worker.getGender() + "," + worker.getAge() + "," + worker.getEducation() + "," + worker.getSalary() + "," + worker.getAddress() + "," + worker.getPhone()); } } if (!found) { System.out.println("没有找到姓名为" + name + "的职工信息"); } } else if (option == 2) { System.out.println("请输入职工号:"); String workerNo = scanner.next(); boolean found = false; for (Worker worker : workers) { if (worker.getWorkerNo().equals(workerNo)) { found = true; System.out.println(worker.getWorkerNo() + "," + worker.getName() + "," + worker.getGender() + "," + worker.getAge() + "," + worker.getEducation() + "," + worker.getSalary() + "," + worker.getAddress() + "," + worker.getPhone()); } } if (!found) { System.out.println("没有找到职工号为" + workerNo + "的职工信息"); } } else { System.out.println("输入有误,请重新输入!"); } } } } ``` 在实现职工信息查询功能之前,我们需要在项目根目录下创建一个staff.txt文件,并将职工信息存储在其中。每行表示一个职工信息,字段之间用逗号分隔,例如: ``` 001,张三,男,28,本科,5000,北京市朝阳区,13800000001 002,李四,女,32,硕士,8000,北京市海淀区,13800000002 003,王五,男,25,本科,4500,北京市西城区,13800000003 ``` 然后,我们就可以运行程序,输入查询方式和要查询的信息,即可查询到指定的职工信息了。

3.职工信息管理系统代码要求:设计一个职工信息管理系统,职工信息包括职工号,姓名,性别,年龄,学历,工资,住址,电 话等(职工号不重复),并具有以下功能: (1)系统以菜单方式工作 (2)职工信息录入功能(职工信息用文件保存) (3)职工信息浏览功能 (4)查询和排序功能:按工资查询、按学历查询 (5)职工信息删除,修改功能

以下是职工信息管理系统的代码实现,包括职工信息的录入、浏览、查询、排序、删除和修改功能: ```python # 定义员工信息类 class Employee: def __init__(self, id, name, gender, age, education, salary, address, phone): self.id = id self.name = name self.gender = gender self.age = age self.education = education self.salary = salary self.address = address self.phone = phone # 定义员工管理系统类 class EmployeeManagementSystem: def __init__(self): self.employees = [] self.filename = 'employees.txt' # 菜单界面 def menu(self): print('================== 职工信息管理系统 ==================') print('1. 录入职工信息') print('2. 浏览职工信息') print('3. 查询职工信息') print('4. 排序职工信息') print('5. 删除职工信息') print('6. 修改职工信息') print('0. 退出系统') print('====================================================') # 录入员工信息 def add_employee(self): id = input('请输入职工号:') for e in self.employees: if e.id == id: print('职工号已存在,请重新输入!') return name = input('请输入姓名:') gender = input('请输入性别:') age = input('请输入年龄:') education = input('请输入学历:') salary = input('请输入工资:') address = input('请输入住址:') phone = input('请输入电话:') employee = Employee(id, name, gender, age, education, salary, address, phone) self.employees.append(employee) self.save_to_file() # 浏览员工信息 def browse_employee(self): print('职工号\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话') for e in self.employees: print('%s\t%s\t%s\t%s\t%s\t%s\t%s\t%s' % (e.id, e.name, e.gender, e.age, e.education, e.salary, e.address, e.phone)) # 查询员工信息 def query_employee(self): print('1. 按工资查询') print('2. 按学历查询') choice = input('请选择查询方式:') if choice == '1': salary = input('请输入工资:') result = [] for e in self.employees: if e.salary == salary: result.append(e) if len(result) > 0: print('职工号\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话') for e in result: print('%s\t%s\t%s\t%s\t%s\t%s\t%s\t%s' % (e.id, e.name, e.gender, e.age, e.education, e.salary, e.address, e.phone)) else: print('没有找到符合条件的员工!') elif choice == '2': education = input('请输入学历:') result = [] for e in self.employees: if e.education == education: result.append(e) if len(result) > 0: print('职工号\t姓名\t性别\t年龄\t学历\t工资\t住址\t电话') for e in result: print('%s\t%s\t%s\t%s\t%s\t%s\t%s\t%s' % (e.id, e.name, e.gender, e.age, e.education, e.salary, e.address, e.phone)) else: print('没有找到符合条件的员工!') else: print('输入有误,请重新选择!') # 排序员工信息 def sort_employee(self): print('1. 按工资排序') print('2. 按学历排序') choice = input('请选择排序方式:') if choice == '1': self.employees.sort(key=lambda x:x.salary) self.browse_employee() elif choice == '2': self.employees.sort(key=lambda x:x.education) self.browse_employee() else: print('输入有误,请重新选择!') # 删除员工信息 def delete_employee(self): id = input('请输入要删除的职工号:') for e in self.employees: if e.id == id: self.employees.remove(e) print('删除成功!') self.save_to_file() return print('职工号不存在,请重新输入!') # 修改员工信息 def modify_employee(self): id = input('请输入要修改的职工号:') for e in self.employees: if e.id == id: name = input('请输入姓名:') gender = input('请输入性别:') age = input('请输入年龄:') education = input('请输入学历:') salary = input('请输入工资:') address = input('请输入住址:') phone = input('请输入电话:') e.name = name e.gender = gender e.age = age e.education = education e.salary = salary e.address = address e.phone = phone print('修改成功!') self.save_to_file() return print('职工号不存在,请重新输入!') # 将员工信息保存到文件中 def save_to_file(self): with open(self.filename, 'w') as f: for e in self.employees: f.write('%s,%s,%s,%s,%s,%s,%s,%s\n' % (e.id, e.name, e.gender, e.age, e.education, e.salary, e.address, e.phone)) # 从文件中读取员工信息 def load_from_file(self): try: with open(self.filename, 'r') as f: for line in f: data = line.strip().split(',') employee = Employee(data[0], data[1], data[2], data[3], data[4], data[5], data[6], data[7]) self.employees.append(employee) except FileNotFoundError: pass # 运行员工管理系统 def run(self): self.load_from_file() while True: self.menu() choice = input('请选择操作:') if choice == '1': self.add_employee() elif choice == '2': self.browse_employee() elif choice == '3': self.query_employee() elif choice == '4': self.sort_employee() elif choice == '5': self.delete_employee() elif choice == '6': self.modify_employee() elif choice == '0': print('谢谢使用,再见!') break else: print('输入有误,请重新选择!') ``` 调用方法: ```python ems = EmployeeManagementSystem() ems.run() ``` 在运行职工信息管理系统之前,需要先创建一个名为"employees.txt"的文件,用于保存员工信息。
阅读全文

相关推荐

最新推荐

recommend-type

职工信息管理系统(C语言)

这个系统设计目的是为了方便地记录和管理职工的基本资料,包括职工号、姓名、性别、年龄、学历、工资、住址和电话等。系统的核心特点是确保职工号的唯一性,以避免数据冲突。 在系统功能方面,它提供了以下操作: ...
recommend-type

c编写—职工信息管理系统源程序

结构体`staff`包含了职工的姓名、编号、性别、年龄、学历、工资、电话和地址等字段,用于存储职工的详细信息。 系统以菜单驱动的方式运行,用户通过选择不同的菜单项来执行相应的操作。主函数`main()`中定义了一个...
recommend-type

postgresql-16.6.tar.gz

postgresql-16.6.tar.gz,PostgreSQL 安装包。 PostgreSQL是一种特性非常齐全的自由软件的对象-关系型数据库管理系统(ORDBMS),是以加州大学计算机系开发的POSTGRES,4.2版本为基础的对象关系型数据库管理系统。POSTGRES的许多领先概念只是在比较迟的时候才出现在商业网站数据库中。PostgreSQL支持大部分的SQL标准并且提供了很多其他现代特性,如复杂查询、外键、触发器、视图、事务完整性、多版本并发控制等。同样,PostgreSQL也可以用许多方法扩展,例如通过增加新的数据类型、函数、操作符、聚集函数、索引方法、过程语言等。另外,因为许可证的灵活,任何人都可以以任何目的免费使用、修改和分发PostgreSQL。
recommend-type

GitHub Classroom 创建的C语言双链表实验项目解析

资源摘要信息: "list_lab2-AquilesDiosT"是一个由GitHub Classroom创建的实验项目,该项目涉及到数据结构中链表的实现,特别是双链表(doble lista)的编程练习。实验的目标是通过编写C语言代码,实现一个双链表的数据结构,并通过编写对应的测试代码来验证实现的正确性。下面将详细介绍标题和描述中提及的知识点以及相关的C语言编程概念。 ### 知识点一:GitHub Classroom的使用 - **GitHub Classroom** 是一个教育工具,旨在帮助教师和学生通过GitHub管理作业和项目。它允许教师创建作业模板,自动为学生创建仓库,并提供了一个清晰的结构来提交和批改学生作业。在这个实验中,"list_lab2-AquilesDiosT"是由GitHub Classroom创建的项目。 ### 知识点二:实验室参数解析器和代码清单 - 实验参数解析器可能是指实验室中用于管理不同实验配置和参数设置的工具或脚本。 - "Antes de Comenzar"(在开始之前)可能是一个实验指南或说明,指示了实验的前提条件或准备工作。 - "实验室实务清单"可能是指实施实验所需遵循的步骤或注意事项列表。 ### 知识点三:C语言编程基础 - **C语言** 作为编程语言,是实验项目的核心,因此在描述中出现了"C"标签。 - **文件操作**:实验要求只可以操作`list.c`和`main.c`文件,这涉及到C语言对文件的操作和管理。 - **函数的调用**:`test`函数的使用意味着需要编写测试代码来验证实验结果。 - **调试技巧**:允许使用`printf`来调试代码,这是C语言程序员常用的一种简单而有效的调试方法。 ### 知识点四:数据结构的实现与应用 - **链表**:在C语言中实现链表需要对结构体(struct)和指针(pointer)有深刻的理解。链表是一种常见的数据结构,链表中的每个节点包含数据部分和指向下一个节点的指针。实验中要求实现的双链表,每个节点除了包含指向下一个节点的指针外,还包含一个指向前一个节点的指针,允许双向遍历。 ### 知识点五:程序结构设计 - **typedef struct Node Node;**:这是一个C语言中定义类型别名的语法,可以使得链表节点的声明更加清晰和简洁。 - **数据结构定义**:在`Node`结构体中,`void * data;`用来存储节点中的数据,而`Node * next;`用来指向下一个节点的地址。`void *`表示可以指向任何类型的数据,这提供了灵活性来存储不同类型的数据。 ### 知识点六:版本控制系统Git的使用 - **不允许使用git**:这是实验的特别要求,可能是为了让学生专注于学习数据结构的实现,而不涉及版本控制系统的使用。在实际工作中,使用Git等版本控制系统是非常重要的技能,它帮助开发者管理项目版本,协作开发等。 ### 知识点七:项目文件结构 - **文件命名**:`list_lab2-AquilesDiosT-main`表明这是实验项目中的主文件。在实际的文件系统中,通常会有多个文件来共同构成一个项目,如源代码文件、头文件和测试文件等。 总结而言,"list_lab2-AquilesDiosT"实验项目要求学生运用C语言编程知识,实现双链表的数据结构,并通过编写测试代码来验证实现的正确性。这个过程不仅考察了学生对C语言和数据结构的掌握程度,同时也涉及了软件开发中的基本调试方法和文件操作技能。虽然实验中禁止了Git的使用,但在现实中,版本控制的技能同样重要。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【三态RS锁存器CD4043的秘密】:从入门到精通的电路设计指南(附实际应用案例)

# 摘要 三态RS锁存器CD4043是一种具有三态逻辑工作模式的数字电子元件,广泛应用于信号缓冲、存储以及多路数据选择等场合。本文首先介绍了CD4043的基础知识和基本特性,然后深入探讨其工作原理和逻辑行为,紧接着阐述了如何在电路设计中实践运用CD4043,并提供了高级应用技巧和性能优化策略。最后,针对CD4043的故障诊断与排错进行了详细讨论,并通过综合案例分析,指出了设计挑战和未来发展趋势。本文旨在为电子工程师提供全面的CD4043应用指南,同时为相关领域的研究提供参考。 # 关键字 三态RS锁存器;CD4043;电路设计;信号缓冲;故障诊断;微控制器接口 参考资源链接:[CD4043
recommend-type

霍夫曼四元编码matlab

霍夫曼四元码(Huffman Coding)是一种基于频率最优的编码算法,常用于数据压缩中。在MATLAB中,你可以利用内置函数来生成霍夫曼树并创建对应的编码表。以下是简单的步骤: 1. **收集数据**:首先,你需要一个数据集,其中包含每个字符及其出现的频率。 2. **构建霍夫曼树**:使用`huffmandict`函数,输入字符数组和它们的频率,MATLAB会自动构建一棵霍夫曼树。例如: ```matlab char_freq = [freq1, freq2, ...]; % 字符频率向量 huffTree = huffmandict(char_freq);
recommend-type

MATLAB在AWS上的自动化部署与运行指南

资源摘要信息:"AWS上的MATLAB是MathWorks官方提供的参考架构,旨在简化用户在Amazon Web Services (AWS) 上部署和运行MATLAB的流程。该架构能够让用户自动执行创建和配置AWS基础设施的任务,并确保可以在AWS实例上顺利运行MATLAB软件。为了使用这个参考架构,用户需要拥有有效的MATLAB许可证,并且已经在AWS中建立了自己的账户。 具体的参考架构包括了分步指导,架构示意图以及一系列可以在AWS环境中执行的模板和脚本。这些资源为用户提供了详细的步骤说明,指导用户如何一步步设置和配置AWS环境,以便兼容和利用MATLAB的各种功能。这些模板和脚本是自动化的,减少了手动配置的复杂性和出错概率。 MathWorks公司是MATLAB软件的开发者,该公司提供了广泛的技术支持和咨询服务,致力于帮助用户解决在云端使用MATLAB时可能遇到的问题。除了MATLAB,MathWorks还开发了Simulink等其他科学计算软件,与MATLAB紧密集成,提供了模型设计、仿真和分析的功能。 MathWorks对云环境的支持不仅限于AWS,还包括其他公共云平台。用户可以通过访问MathWorks的官方网站了解更多信息,链接为www.mathworks.com/cloud.html#PublicClouds。在这个页面上,MathWorks提供了关于如何在不同云平台上使用MATLAB的详细信息和指导。 在AWS环境中,用户可以通过参考架构自动化的模板和脚本,快速完成以下任务: 1. 创建AWS资源:如EC2实例、EBS存储卷、VPC(虚拟私有云)和子网等。 2. 配置安全组和网络访问控制列表(ACLs),以确保符合安全最佳实践。 3. 安装和配置MATLAB及其相关产品,包括Parallel Computing Toolbox、MATLAB Parallel Server等,以便利用多核处理和集群计算。 4. 集成AWS服务,如Amazon S3用于存储,AWS Batch用于大规模批量处理,Amazon EC2 Spot Instances用于成本效益更高的计算任务。 此外,AWS上的MATLAB架构还包括了监控和日志记录的功能,让用户能够跟踪和分析运行状况,确保应用程序稳定运行。用户还可以根据自己的需求自定义和扩展这些模板和脚本。 在使用AWS上的MATLAB之前,用户需要了解MathWorks的许可协议,明确自己的许可证是否允许在云环境中使用MATLAB,并确保遵守相关法律法规。MathWorks提供了广泛的资源和支持,帮助用户快速上手,有效利用AWS资源,以及在云端部署和扩展MATLAB应用程序。 综上所述,AWS上的MATLAB参考架构是为希望在AWS云平台上部署MATLAB的用户提供的一种快速、简便的解决方案。它不仅减少了手动配置的复杂性,还为用户提供了广泛的资源和指导,以确保用户能够在云环境中高效、安全地使用MATLAB。"
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

铁路售票系统用例图:异常流处理的黄金法则

![铁路售票系统用例图:异常流处理的黄金法则](https://opengraph.githubassets.com/afac9d71167fe51e2e95e6b89ecf588c94077f4e2d4e82c217ba436f21dce30d/DarshanGH/Railway-Ticket-Booking-System) # 摘要 本文全面探讨了铁路售票系统的异常流处理问题,阐述了用例图在系统设计中的重要性及其绘制方法,同时分析了异常流的定义、设计原则、最佳实践及其在铁路售票系统中的应用。文章进一步深入到异常流识别、分类、处理流程设计以及用户界面处理的策略,确保异常情况下的系统稳定性和