Python3.5 day4作业:对员工信息文件,实现增删改查操作。
需求:
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)
Python3.5 day4作业:对员工信息文件,实现增删改查操作。的更多相关文章
- C#+Access 员工信息管理--简单的增删改查操作和.ini配置文件的读写操作。
1.本程序的使用的语言是C#,数据库是Access2003.主要是对员工信息进行简单的增删改查操作和对.ini配置文件的读写操作. 2.代码运行效果如下: 功能比较简单.其中在得到查询结果后,在查询结 ...
- Java使用DOM4J对XML文件进行增删改查操作
Java进行XML文件操作,代码如下: package com.founder.mrp.util; import java.io.File; import java.util.ArrayList; i ...
- python文件实现增删改查操作
# coding = utf-8 import os import json import re ''' 本程序旨在将练习基础知识部分,包括: 列表,元组,字典,文件,函数,字符串等知识 实现的功能: ...
- 老男孩Day4作业:员工信息查询系统
1.作业需求: (1).工信息表程序,实现增删改查操作: (2).可进行模糊查询,语法至少支持下面3种: select name,age from staff_table where ...
- MyBatis学习(二)、SQL语句映射文件(2)增删改查、参数、缓存
二.SQL语句映射文件(2)增删改查.参数.缓存 2.2 select 一个select 元素非常简单.例如: <!-- 查询学生,根据id --> <select id=" ...
- MyBatis学习 之 二、SQL语句映射文件(2)增删改查、参数、缓存
目录(?)[-] 二SQL语句映射文件2增删改查参数缓存 select insert updatedelete sql parameters 基本类型参数 Java实体类型参数 Map参数 多参数的实 ...
- 【练习】Python第四次:实现对文件的增删改查
一,实现对文件的增删改查 (一),三级菜单的处理结构及退出技巧:使用TAG标记 tag=True while tag: print('leve1') choice=input("level1 ...
- 基于SpringMVC的文件(增删改查)上传、下载、更新、删除
一.项目背景 摘要:最近一直在忙着项目的事,3个项目过去了,发现有一个共同的业务,那就是附件的处理,附件包括各种文档,当然还有图片等特殊文件,由于时间的关系,每次都是匆匆忙忙的搞定上线,称这项目的空档 ...
- 用dom4j解析xml文件并执行增删改查操作
转自:https://www.aliyun.com/jiaocheng/1339446.html xml文件: <?xml version="1.0" encoding=&q ...
随机推荐
- python3 黑板客爬虫闯关游戏(四)
这关较第三关难度增加许多,主要多了并发编程 密码一共有100位,分布在13页,每页打开的时间在15秒左右,所以理所当然的想到要用并发,但是后来发现同IP访问间隔时间不能小于8秒,不然会返回404,所以 ...
- css文件 引用后不起作用
你如果填写的是相对路径,那么检查一下路径是否正确. 如果相对路径正确,那么有可能你的css样式的层级错误(概率也不低),比如说图片的引用路径发生了改变等等. 要看你预览的浏览器是什么,我经常遇到IE预 ...
- [java]OutOfMemoryError 原因及解决办法
导致OutOfMemoryError异常的常见原因有以下几种: 内存中加载的数据量过于庞大,如一次从数据库取出过多数据: 集合类中有对对象的引用,使用完后未清空,使得JVM不能回收: 代码中存在死循环 ...
- mui学习记录
1.页面间传值 2.mui如何增加自定义icon图标 http://ask.dcloud.net.cn/article/128 3.设计基于HTML5的APP登录功能及安全调用接口的方式(原理篇) h ...
- ios Carthage
使用CocoaPods来管理第三方框架很多人都知道,相对来说Carthage比较陌生,Carthage也是来管理第三方框架的,既然已经有了Cocoapods为什么还要有Carthage呢?使用Cart ...
- iOS之小门道道
1.代理方法不执行 很多时候在你代理方法不执行时,小样,你看看你设置代理了吗?
- scp 从远程服务器上一下载文件
scp -P202 xx3.x6.xx.xx:/usr/local/zookeeper-.zip /tmp #指定远程服务器的端口和远程服务器的目标文件 ,最后指定要下载到本的地目录 也可以从远程服务 ...
- JS实现常用排序算法—经典的轮子值得再造
关于排序算法的博客何止千千万了,也不多一个轮子,那我就斗胆粗制滥造个轮子吧!下面的排序算法未作说明默认是从小到大排序. 1.快速排序2.归并排序3.冒泡排序4.选择排序(简单选择排序)5.插入排序(直 ...
- 简单爬虫,突破IP访问限制和复杂验证码,小总结
简单爬虫,突破复杂验证码和IP访问限制 文章地址:http://www.cnblogs.com/likeli/p/4730709.html 好吧,看题目就知道我是要写一个爬虫,这个爬虫的目标网站有 ...
- 【积累篇:他山之石,把玉攻】解决XP 系统 .Net Framework 4安装时出现严重错误 (0x80070643)
第一步: 1.开始——运行——输入cmd——回车——在打开的窗口中输入net stop WuAuServ 2.开始——运行——输入%windir% 3.在打开的 的窗口中有个文件夹叫SoftwareD ...