需求:

1.可进行模糊查询,语法至少支持下面3种:

1.select name,age from staff_table where age > 22

2.select  * from staff_table where dept = IT

3.查到的信息,打印后,最后面还要显示查到的条数

2.可创建新员工纪录,以phone做唯一键,staff_id需自增

3.可删除指定员工信息纪录,输入员工id,即可删除

4.可修改员工信息,语法如下:

1.UPDATE staff_table SET dept= 无 where dept = IT

注意:请输入正确的语句进行查询,否则会报错。

#_*_coding:utf-8_*_
import os
def fetch(data):
#查询语法一:select name,age from staff_table where age > 22
#查询语法二:select * from staff_table where dept = IT
data1 = data.split(" ")
directory = ["staff_id", "name", "age", "phone", "dept", "enroll-date"]
if data == ("select name,age from staff_table where age > %s" %(data1[7])):
with open("xinxi", encoding="utf-8") as f:
list = []
list1 = []
list2 = []
for line in f:
i = line.strip().split(",")
w = i[1]
e = i[2]
a = [w, e]
if e > data1[7]:
list2.append(a)
for i in list2:
print(i)
print("查询到 %s 条符合的信息" %len(list2))
else:
with open("xinxi", encoding="utf-8") as f:
list = []
for line in f:
i = line.strip().split(",")
q = i[0]
w = i[1]
e = i[2]
r = i[3]
t = i[4]
y = i[5]
if data == ("select * from staff_table where %s = %s" % (data1[5], i[(directory.index(data1[5]))])):
list.append(i)
else:
continue
for j in list:
print('.'.join(j))
print("查询到 %s 条符合的信息" %len(list))
return 0
def add(data):
#添加语法: name,age,phone,dept,enroll-date (例如:王新凯,22,11111111111,IT,2015-10-31)
data1 = data.split(",")
f= open("xinxi",encoding="utf-8")
all_list = []
list = []
phone_list = []
for line in f:
i = line.strip().split(",")
q = i[3]
phone_list.append(q) if data1[2] in phone_list:
print("手机号已存在")
f.close()
else:
f1 = open("xinxi", "r+", encoding="utf-8")
for line in f1:
lines = line.strip().split(",")
# print(lines)
list.append(lines)
i = line.strip().split(",")
w = str(int(list[-1][0]) + 1)
data1.insert(0, w)
print(data1)
data1 = ','.join(data1)
f1.write("\n")
f1.write(data1)
f1.close()
print("添加成功!!!")
def remove(data):
#删除语法:delete from staff_table where staff_id = 12
data1 = data.split(" ")
if data == ("delete from staff_table where staff_id = %s" %data1[6]):
with open("xinxi", encoding="utf-8") as f:
list = []
for line in f:
i = line.strip().split(",")
i1 = line.splitlines()
q = i[0]
if data1[6] == q:
i2 = ','.join(i1)
print(i2)
list.append(i)
a = i2
f = open("xinxi", encoding="utf-8")
f1 = open("back", "a+", encoding="utf-8")
for i in f:
if a in i:
i = i.replace(a, "").strip()
f1.write(i)
f1.flush()
f.close()
f1.close()
os.remove("xinxi")
os.rename("back","xinxi")
print("删除成功!!!")
return
def change(data):
#修改请输入(注意空格和没有引号):UPDATE staff_table SET dept = IT where dept = 运维
data1 = data.split(" ")
print(data1)
# a =','.join(data1[3])
# print(a)
directory = ["staff_id", "name", "age", "phone", "dept", "enroll-date"]
var = int(directory.index(data1[3]))
with open("xinxi", encoding="utf-8") as f,\
open("back","w",encoding="utf-8")as f1:
for line in f:
lines = line.strip()
print(lines)
if data1[5] in lines:
lines = lines.replace(data1[5],data1[9])
f1.write(lines)
f1.write("\n")
f1.flush()
os.remove("xinxi")
os.rename("back","xinxi")
print("修改成功!!!") if __name__ == "__main__":
msg = """
1:查询
2:添加
3:删除
4:修改
5:退出
"""
msg_dict = {
"": fetch,
"": add,
"": remove,
"": change,
"": exit,
}
while True:
print(msg)
choice = input("输入序号>>:")
if len(choice) == 0 or choice not in msg_dict: continue
if choice =='':break
data = input("请输入数据>>:").strip()
msg_dict[choice](data)

最新文章

  1. 用五分钟重温委托,匿名方法,Lambda,泛型委托,表达式树
  2. Mysql中sql_mode详解
  3. nginx图片处理
  4. BUG描述规范
  5. css样式自适应,支持数字
  6. 【学习笔记】移动Web手册(PPK力作)
  7. poj 2153 Rank List
  8. 邮件Mail
  9. Eclipse Memory Analysis进行堆转储文件分析
  10. 不用position,让div垂直居中
  11. 大端(Big Endian)与小端(Little Endian)
  12. GBK和UTF8有什么区别
  13. sql必知必会笔记
  14. Nginx - 代理、缓存
  15. Element ui 日期限制范围
  16. 什么是“闭包”(closure)为什么要用它?
  17. RQY大佬一晚报告总结
  18. 解决eclipse的自动换行问题。
  19. Gym 102091L Largest Allowed Area 【二分+二维前缀和】
  20. 希尔排序——Shell Sort

热门文章

  1. Python 之旅
  2. [PHP][位转换积累]之异或运算的简单加密应用
  3. 正则表达式 判断 ip:端口 形式
  4. 【翻译】Fluent NHibernate介绍和入门指南
  5. go:结构体的可访问性
  6. sharepoint关键位置
  7. Visual Studio高级调试技巧
  8. Notepad++正则表达式语法
  9. 浅析/dev/shm
  10. Oracle sql连接