实在是太low了,终究是自己写的,记录下

#!/usr/bin/env python
# coding=utf8
import os, re
#这里我把查询这块分为3个函数了,纠结了很久是放一起还是分开,最后还是分开了,容易写一些
def search_age_above_22(): #定义年纪大于22岁函数
new = [] # 把读取到的文件写入至此列表
temp = [] # 记录查询年龄大于22岁的总数列表 with open("Information.txt", "r", encoding="utf8") as file:
for line in file.readlines():
new.append(line.strip().split(","))
for each_line in new:
if each_line[2] > "22":
temp.append(each_line[2])
print(each_line[1:3])
print("查到年龄大于22岁的总数为:%s" % len(temp)) def search_depot_of_IT(): #定义部门为IT的函数
new = [] # 把读取到的文件写入至此列表
temp = [] # 记录查询部门为IT的总数列表
with open("Information.txt", "r", encoding="utf8") as file:
for line in file.readlines():
new.append(line.strip().split(","))
for each_line in new:
if each_line[4] == "IT":
temp.append(each_line[4])
print(str(each_line[::]))
print("查到部门为IT的总数为:%s" % len(temp)) def search_date_of_2013(): #定义开始工作日期为2013年的函数
new = [] # 把读取到的文件写入至此列表
temp = [] # 记录查询开始工作日期为2013年的总数列表
with open("Information.txt", "r", encoding="utf8") as file:
for line in file.readlines():
new.append(line.strip().split(","))
for each_line in new:
if re.search("2013", each_line[-1]):
temp.append(each_line[5])
print(each_line[::])
print("查到工作时间在2013年名单总数为:%s" % len(temp)) def add(): #定义增加函数
new = [] # 把读取到的文件写入至此列表
temp = [] #此列表为了自增而建,代码写的很low
user_input = str(input("请输入类似于[吴东杭,21,17710890829,运维,1995-08-29]的一串东西:"))
with open("Information.txt", "r", encoding="utf8") as read_file, open("NewInformation.txt", "w+",
encoding="utf8")as write_file:
for line in read_file:
new.append(line.strip().split(","))
for new_line in new:
# i.append(j)
temp.append(new_line)
# print(i[-1][0])
Added_Data = "%d,%s" % (int(temp[-1][0]) + 1, user_input)
temp.append(Added_Data.split(','))
for each_line in temp:
write_file.write(','.join(each_line).strip("")) # 通过内置方法join把列表转换为字符串
write_file.write("\n") # 写入这行,可使文件换行
os.rename("Information.txt", "Information.bak")
os.rename("NewInformation.txt", "Information.txt")
os.remove("Information.bak") def delete(): #定义删除函数
ReadFile = []
User_Choice = int(input("请输入staff_id号:"))
with open("Information.txt", "r", encoding="utf8") as read_file, open("NewInformation.txt", "w+",
encoding="utf8") as write_file:
for line in read_file:
ReadFile.append(line.strip().split(","))
for each_line in ReadFile:
if User_Choice == int(each_line[0]):
ReadFile.remove(ReadFile[User_Choice - 1])
for new_line in ReadFile:
write_file.write(','.join(new_line).strip("")) # 通过内置方法join把列表转换为字符串
write_file.write("\n") # 写入这行,可使文件换行
os.rename("Information.txt", "Information.bak")
os.rename("NewInformation.txt", "Information.txt")
os.remove("Information.bak") def modify(): #定义更改函数
if not os.path.exists("Information.txt"):
exit(-1)
User_Input = str(input("请输入:"))
with open("Information.txt", "r", encoding="utf8") as read_file, open("NewInformation.txt", "w+",
encoding="utf8") as write_file:
for line in read_file.readlines():
write_file.write(line.replace("IT", User_Input))
os.rename("Information.txt", "Information.bak")
os.rename("NewInformation.txt", "Information.txt")
os.remove("Information.bak") if __name__ == '__main__':
msg = '''
1:查询年龄大于22岁学生信息
2:查询部门为IT学生信息
3:查询工作开始时间在2013年学生信息
4:添加
5:删除
6:修改
7:退出
'''
menu_dic = { '1': search_age_above_22,
'2': search_depot_of_IT,
'3': search_date_of_2013,
'4': add,
'5': delete,
'6': modify,
'7': exit,
}
while True:
print(msg)
choice = input("操作>>: ").strip()
if len(choice) == 0 or choice not in menu_dic or choice.isalpha():
print("温馨提示:请输入1-7之间的数字")
continue
if choice == '7': break
menu_dic[choice]()

  

day4作业之信息表的更多相关文章

  1. day12 python作业:员工信息表

    作业要求: 周末大作业:实现员工信息表文件存储格式如下:id,name,age,phone,job1,Alex,22,13651054608,IT2,Egon,23,13304320533,Tearc ...

  2. python作业员工信息表程序(第四周)

    作业需求: 1. 员工信息表程序,实现增删改查操作: 2. 可进行模糊查询,语法至少支持下面3种: select name,age from staff_table where age > 22 ...

  3. python基础之员工信息表作业

    周末大礼包 文件存储格式如下: id, name, age, phone, job 1, Alex, 22, 13651054608, IT 2, Egon, 23, 13304320533, Tea ...

  4. 老男孩Day4作业:员工信息查询系统

    1.作业需求: (1).工信息表程序,实现增删改查操作: (2).可进行模糊查询,语法至少支持下面3种:          select name,age from staff_table where ...

  5. s9.16作业,员工信息表

    转载https://blog.csdn.net/qq_35883464/article/details/83151464 实现员工信息表文件存储格式如下:id,name,age,phone,job1, ...

  6. 2014-11-9------- 设有一数据库,包括四个表:学生表(Student)、课程表(Course)、成绩表(Score)以及教师信息表(Teacher)。

    一.            设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四个表的结构分别如表1-1的表(一)~表( ...

  7. SysErrorMessage 函数和系统错误信息表

    在看 API 文档时, 我们经常见到 GetLastError; 它可以返回操作后系统给的提示.但 GetLastError 返回的只是一个信息代码, 如何返回对应的具体信息呢?FormatMessa ...

  8. Delphi SysErrorMessage 函数和系统错误信息表

    在看 API 文档时, 我们经常见到 GetLastError; 它可以返回操作后系统给的提示. 但 GetLastError 返回的只是一个信息代码, 如何返回对应的具体信息呢? FormatMes ...

  9. delphi SysErrorMessage 函数和系统错误信息表 good

    在看 API 文档时, 我们经常见到 GetLastError; 它可以返回操作后系统给的提示. 但 GetLastError 返回的只是一个信息代码, 如何返回对应的具体信息呢? FormatMes ...

随机推荐

  1. .htaccess设置静态资源缓存(即浏览器缓存)

    在HTTP标头中为静态资源设置过期日期或最长存在时间,可指示浏览器从本地磁盘中加载以前下载的资源,而不是通过网络加载.这样, 网站加载速度会更快. 下面的代码都需要放到.htaccess中才能生效. ...

  2. max_allowed_packet自动恢复

    https://dev.mysql.com/doc/refman/5.5/en/packet-too-large.html http://blog.chinaunix.net/uid-20304801 ...

  3. C++ map的使用

    C++ map的基本操作和使用 来源:(http://blog.sina.com.cn/s/blog_61533c9b0100fa7w.html) - C++ map的基本操作和使用_Live_新浪博 ...

  4. 字符串匹配(KMP算法)

    KMP算法,是由Knuth,Morris,Pratt共同提出的模式匹配算法,其对于任何模式和目标序列,都可以在线性时间内完成匹配查找,而不会发生退化,是一个非常优秀的模式匹配算法. 举个例子来说,如果 ...

  5. 优化Webstorm

    Webstorm这个编辑器还是很强大的,而且版本更新得快,支持最新的typescript,就是性能越来越低. 本文总结了一些优化Webstorm的有效方法,希望对大家有所帮助! 测试环境 Mac OS ...

  6. try-catch和throw,throws的区别和联系

    转载:http://blog.sina.com.cn/s/blog_62148d1e0100hkqc.html 区别一:throw 是语句抛出一个异常:throws 是方法抛出一个异常: throw语 ...

  7. jQuery Easy UI 开发笔记

    1.jQuery Easy UI主要的运行原理是通过核心的代码调用插件来实现UI效果的 2.jQuery Easy UI插件与插件之间的关系是: 一.独立式插件: 独立式插件是指:不与其他的插件具有相 ...

  8. sql 随机函数newid()

    newid()返回的是uniqueidentifier类型的唯一值.newid()每次产生的值都不一样 从表中随机获取前N条记录 select top N *  from table_name ord ...

  9. [USACO2003][poj2018]Best Cow Fences(数形结合+单调队列维护)

    http://poj.org/problem?id=2018 此乃神题……详见04年集训队论文周源的,看了这个对斜率优化dp的理解也会好些. 分析: 我们要求的是{S[j]-s[i-1]}/{j-(i ...

  10. 16.C#初见Lambda表达式及表达式树(九章9.1-9.3)

    在说明Lambda相关知识前,我们需要了解Lambda表达式常用于LINQ,那么我们来聊下LINQ. LINQ的基本功能就是创建操作管道,以及这些操作需要的任何状态.这些操作表示了各种关于数据的逻辑: ...