路飞学城Python-Day10(practise)
作业:
现要求你写一个简单的员工信息增删该查程序,需求如下:
当然此表在文件存储时可以这样表示
1,Alex Li,22,13651054608,IT,2013-04-01
2,Jack Wang,28,13451024608,HR,2015-01-07
3,Rain Wang,21,13451054608,IT,2017-04-01
4,Mack Qiao,44,15653354208,Sales,2016-02-01
5,Rachel Chen,23,13351024606,IT,2013-03-16
6,Eric Liu,19,18531054602,Marketing,2012-12-01
7,Chao Zhang,21,13235324334,Administration,2011-08-08
8,Kevin Chen,22,13151054603,Sales,2013-04-01
9,Shit Wen,20,13351024602,IT,2017-07-03
10,Shanshan Du,26,13698424612,Operation,2017-07-02
1.可进行模糊查询,语法至少支持下面3种查询语法:
find name,age from staff_table where age > 22
find * from staff_table where dept = "IT"
find * from staff_table where enroll_date like "2013"
2.可创建新员工纪录,以phone做唯一键(即不允许表里有手机号重复的情况),staff_id需自增
语法: add staff_table Alex Li,25,134435344,IT,2015-10-29
3.可删除指定员工信息纪录,输入员工id,即可删除
语法: del from staff_table where id=3
4.可修改员工信息,语法如下:
UPDATE staff_table SET dept="Market" WHERE dept = "IT" 把所有dept=IT的纪录的dept改成Market
UPDATE staff_table SET age=25 WHERE name = "Alex Li" 把name=Alex Li的纪录的年龄改成25
5.以上每条语名执行完毕后,要显示这条语句影响了多少条纪录。 比如查询语句 就显示 查询出了多少条、修改语句就显示修改了多少
import os
import re def create_staff_table():
'''
1.如果表存在就加载表,不存在就创建信息表
2.正常打印表
:return:
'''
msg = [
'1,Alex Li,22,13651054608,IT,2013-04-01',
'2,Jack Wang,28,13451024608,HR,2015-01-07',
'3,Rain Wang,21,13451054608,IT,2017-04-01',
'4,Mack Qiao,44,15653354208,Sales,2016-02-01',
'5,Rachel Chen,23,13351024606,IT,2013-03-16',
'6,Eric Liu,19,18531054602,Marketing,2012-12-01',
'7,Chao Zhang,21,13235324334,Administration,2011-08-08',
'8,Kevin Chen,22,13151054603,Sales,2013-04-01',
'9,Shit Wen,20,13351024602,IT,2017-07-03',
'10,Shanshan Du,26,13698424612,Operation,2017-07-02',
]
if not os.path.isfile('staff_table'):
with open('staff_table', 'w+', encoding='utf-8') as f:
for i in msg:
f.write(i+'\n')
print('初始化文件已完成')
else:
with open('staff_table', 'r', encoding='utf-8') as f:print('+-----------staff_table------------+\n'+f.read()+'+-----------end------------+') def add_info():
'''
增加用户信息
1.phone必须是唯一值
2.id自增
3.语法 add staff_table Alex Li,25,134435344,IT,2015-10-29
:return:
'''
add_in = input('增加语法如下\nadd staff_table Alex Li,25,134435344,IT,2015-10-29\n请输入增加命令>>').strip().split(',')
if add_in[0].split(' ')[0] == 'add' and add_in[0].split(' ')[1] == 'staff_table':
add_out = ' '.join(add_in[0].split(' ')[2:]) + ',' + ','.join(add_in[1:])
with open('staff_table', 'a+', encoding='utf-8') as f:
phone_list = []
f.seek(0)
for i in f:
phone_list.append(i.strip().split(',')[3])
if add_in[2] not in phone_list:
staff_id = int(i.strip().split(',')[0]) + 1
f.write(str(staff_id) + ',' + add_out + '\n')
print('1条记录已新增!')
else:
print('该手机号已经注册了!')
else:
print('错误的命令') def del_info():
'''
删除用户信息
1.只能根据用户的id删除
2.语法 del from staff where id=x
(满足条件:1.语法验证正确;)
【bug】:删除不存在id也不提示错误信息
:return:
'''
del_in = input('删除语法如下\ndel from staff where id=x\n请输入删除命令>>').strip().split(' ')
if del_in[0] + del_in[1] + del_in[2] + del_in[3] + del_in[4] == 'delfromstaffwhereid=' + re.split('=', del_in[4])[1]:#验证语法是否正确
old_file = open('staff_table','r+',encoding='utf-8')
new_file = open('staff_table1','w',encoding='utf-8')
for i in old_file:
line = i.strip().split(',')
if re.split('=', del_in[4])[1] != line[0]:
new_file.write(i)
new_file.close()
old_file.close()
os.remove('staff_table')
os.rename('staff_table1','staff_table')
else:
print('错误的语法') def change_info():
'''
修改语法:
UPDATE staff_table SET dept="Market" WHERE dept = "IT" 把所有dept=IT的纪录的dept改成Market
UPDATE staff_table SET age=25 WHERE name = "Alex Li" 把name=Alex Li的纪录的年龄改成25
1.验证语法
2.新建文件并修改msg
3.重写文件并删除原文件
-----------------------
0.找到所有输入中查找的值
1.拿到输入的值
2.替换原值
3.存储变更的数据(按索引)
4.排序后覆盖原文件
:return:
'''
change_in = input('更新语法如下\nUPDATE staff_table SET dept="Market" WHERE dept = "IT"\n'
'UPDATE staff_table SET age=25 WHERE name = "Alex Li"\n请输入更新命令>>').strip().split(' ')
dept_list = [] # 查询到的数据放这个列表
dept_list_left = [] # 没查到的数据放这个列表
dept_list_temp = [] # 我都忘这个干啥用的..
if change_in[0] == 'UPDATE'.upper() and change_in[1] == 'staff_table' \
and change_in[2] == 'SET'.upper() and change_in[4] == 'WHERE'.upper() and change_in[6] == 'dept':
change_in_dept_set = re.split('=', change_in[3])[1].replace('"', '') # 1.拿到输入的Market
change_in_dept_file = change_in[8].replace('"', '') # 1.拿到输入的IT
f = open('staff_table', 'r+', encoding='utf-8')
n_f = open('staff_table_new', 'w', encoding='utf-8')
for line in f:
dept_list_temp.append(line.strip())
for l in dept_list_temp:
if change_in_dept_file == l.strip().split(',')[4]:
l1 = l.replace(l.strip().split(',')[4], change_in_dept_set)
dept_list.append(l1)
else:
dept_list_left.append(l)
res = dept_list + dept_list_left
for lines in res:
n_f.write(lines + '\n')
f.close()
n_f.close()
os.remove('staff_table')
os.rename('staff_table_new', 'staff_table')
print('\033[31;1m%s\033[0m条数据受到影响!' % len(set(dept_list)))
elif change_in[0] == 'UPDATE'.upper() and change_in[1] == 'staff_table' \
and change_in[2] == 'SET'.upper() and change_in[4] == 'WHERE'.upper() and change_in[6] == 'name':
f = open('staff_table', 'r+', encoding='utf-8')
n_f = open('staff_table_new', 'w', encoding='utf-8')
change_in_dept_set = re.split('=', change_in[3])[1] # 1.拿到输入的age
change_in_dept_file = ' '.join(change_in[8:]).replace('"', '') # 2.拿到输入的name
for line in f:
dept_list_temp.append(line.strip())
for l in dept_list_temp:
if change_in_dept_file == l.strip().split(',')[1]:
l1 = l.replace(l.strip().split(',')[2], change_in_dept_set)
dept_list.append(l1)
else:
dept_list_left.append(l)
res = dept_list + dept_list_left
for lines in res:
n_f.write(lines + '\n')
f.close()
n_f.close()
os.remove('staff_table')
os.rename('staff_table_new', 'staff_table')
print('\033[31;1m%s\033[0m条数据受到影响!' % len(set(dept_list)))
else:
print('错误的语法!') def find_info():
'''
1.可进行模糊查询,语法至少支持下面3种查询语法:
find name,age from staff_table where age > 22
find * from staff_table where dept = "IT"
find * from staff_table where enroll_date like "2013"
:return:
'''
find_in = input('查询语法如下\n'
'find name,age from staff_table where age > 22\n'
'find * from staff_table where dept = "IT"\n'
'find * from staff_table where enroll_date like "2013"\n'
'请输入查询命令>>').strip().split(' ')
find_list = []
if find_in[1] == 'name,age' and find_in[3] =='staff_table' and find_in[5] == 'age':
with open('staff_table','r',encoding='utf-8') as f:
for line in f:
if int(find_in[7]) < int(line.strip().split(',')[2]):
find_list.append(line)
print('+--staff_table--+\n'+'+name------'+'--age+')
for i in find_list:
print('|'+i.strip().split(',')[1], i.strip().split(',')[2]+'\t|')
print('+---------------+\n'+'查询到\033[31;1m%s\033[0m条数据!'% len(set(find_list)))
elif find_in[1] == '*' and find_in[3] =='staff_table' and find_in[5] =='dept':
with open('staff_table','r',encoding='utf-8') as f:
for line in f:
if find_in[7].replace('"','') == line.strip().split(',')[4]:
find_list.append(line.strip())
print('+----------staff_table------+\n')
for i in find_list:
print(i)
print('+-----------------------------+\n'+'查询到\033[31;1m%s\033[0m条数据!' % len(set(find_list)))
elif find_in[1] == '*' and find_in[3] =='staff_table' and find_in[5] == 'enroll_date':
with open('staff_table', 'r', encoding='utf-8') as f:
for line in f:
if find_in[7].replace('"', '') == re.split('-', line.strip().split(',')[5])[0]:
find_list.append(line.strip())
print('+----------staff_table------+\n')
for i in find_list:
print(i)
print('+-----------------------------+\n' + '查询到\033[31;1m%s\033[0m条数据!' % len(set(find_list)))
else:
print('错误的命令!') def main():
while True:
print('+--------操作界面--------+\n0.打印当前信息\n1.查询员工信息\n2.新增员工信息\n3.删除员工信息\n4.修改员工信息\n5.退出\n+--------end--------+')
choice = input('请输入您的选项>>>').strip()
if choice == '':
find_info()
elif choice == '':
add_info()
elif choice == '':
del_info()
elif choice == '':
change_info()
elif choice == '':
exit()
elif choice == '':
create_staff_table()
else:
print('错误的命令,请重试!') if __name__ == '__main__':
create_staff_table()
main()
7月9日安排
上午 完成 函数所有作业及视频学习和笔记,并完成员工信息表的增加和删除
下午 完成员工信息表的修改和查询
晚上 完成模块10个视频,记录笔记
路飞学城Python-Day10(practise)的更多相关文章
- 路飞学城—Python爬虫实战密训班 第三章
路飞学城—Python爬虫实战密训班 第三章 一.scrapy-redis插件实现简单分布式爬虫 scrapy-redis插件用于将scrapy和redis结合实现简单分布式爬虫: - 定义调度器 - ...
- 路飞学城—Python爬虫实战密训班 第二章
路飞学城—Python爬虫实战密训班 第二章 一.Selenium基础 Selenium是一个第三方模块,可以完全模拟用户在浏览器上操作(相当于在浏览器上点点点). 1.安装 - pip instal ...
- 路飞学城Python爬虫课第一章笔记
前言 原创文章,转载引用务必注明链接.水平有限,如有疏漏,欢迎指正. 之前看阮一峰的博客文章,介绍到路飞学城爬虫课程限免,看了眼内容还不错,就兴冲冲报了名,99块钱满足以下条件会返还并送书送视频. 缴 ...
- 路飞学城-Python开发集训-第3章
学习心得: 通过这一章的作业,使我对正则表达式的使用直接提升了一个level,虽然作业完成的不怎么样,重复代码有点多,但是收获还是非常大的,有点找到写代码的感觉了,遗憾的是,这次作业交过,这次集训就结 ...
- 路飞学城-Python开发集训-第1章
学习体会: 在参加这次集训之前我自己学过一段时间的Python,看过老男孩的免费视频,自我感觉还行,老师写的代码基本上都能看懂,但是实际呢?....今天是集训第一次交作业的时间,突然发现看似简单升级需 ...
- 路飞学城-Python开发集训-第4章
学习心得: 学习笔记: 在python中一个py文件就是一个模块 模块好处: 1.提高可维护性 2.可重用 3.避免函数名和变量名冲突 模块分为三种: 1.内置标准模块(标准库),查看所有自带和第三方 ...
- 路飞学城-Python开发集训-第2章
学习心得: 这章对编码的讲解超级赞,现在对于编码终于有一点认知了,但还没有大彻大悟,还需要更加细心的琢磨一下Alex博客和视频,以前真的是被编码折磨死了,因为编码的问题而浪费的时间很多很多,现在终于感 ...
- 路飞学城Python-Day19(practise)
# 特性1.继承:2.多态:3.封装 # 1.继承的用处:通过继承就可以解决类与类之间的代码冗余关系 # 2.多态的用处:1.增加了程序的灵活性,以不变应万变,使用者都是同一种形式去调用(func(a ...
- 路飞学城-Python开发-第二章
''' 数据结构: menu = { '北京':{ '海淀':{ '五道口':{ 'soho':{}, '网易':{}, 'google':{} }, '中关村':{ '爱奇艺':{}, '汽车之家' ...
- 路飞学城-Python开发-第三章
# 数据结构: # goods = [ # {"name": "电脑", "price": 1999}, # {"name&quo ...
随机推荐
- 利用Windows2003 IP安全策略实现服务器远程桌面端口(3389)访问控制
1 开始 → 运行 → 对话框中输入gpedit.msc → 确定 2 打开“组策略编辑器” 计算机配置 → Windows配置 → 右键点击“IP安全策略,在 本地计算机” →选择“创建IP安全策略 ...
- 第六章 Python之迭代器与生成器
迭代器 迭代:迭代是一个重复的过程,每次重复即一次迭代,并且每次迭代的结果是下一次重复的初始值 l=['a','b','c'] count=0 while count < len(l): pri ...
- node——module.exports
module.exports 1. 在a.js中 var b=require('./b.js'); console.log(b); 在b.js中 function add(x,y){ return x ...
- HDU 3117 Fibonacci Numbers( 矩阵快速幂 + 数学推导 )
链接:传送门 题意:给一个 n ,输出 Fibonacci 数列第 n 项,如果第 n 项的位数 >= 8 位则按照 前4位 + ... + 后4位的格式输出 思路: n < 40时位数不 ...
- [luogu2592 ZJOI2008] 生日聚会 (计数dp)
题目描述 今天是hidadz小朋友的生日,她邀请了许多朋友来参加她的生日party. hidadz带着朋友们来到花园中,打算坐成一排玩游戏.为了游戏不至于无聊,就座的方案应满足如下条件: 对于任意连续 ...
- 排序代码(python,c++) 及 基本算法复杂度
0.导语 本节为手撕代码系列之第一弹,主要来手撕排序算法,主要包括以下几大排序算法: 直接插入排序 冒泡排序 选择排序 快速排序 希尔排序 堆排序 归并排序 1.直接插入排序 [算法思想] 每一步将一 ...
- crm 系统项目(二) admin 后台操作表格
crm 系统项目(二) admin 后台操作表格 1. app下创建 templates 运行的时候 先找全局的templates——> 按照app的注册顺序找templates中的文件 2. ...
- 小学生都能学会的python(<lamda匿名函数,sorted(),filter(),map(),递归函数>)
小学生都能学会的python(<<lamda匿名函数,sorted(),filter(),map(),递归函数,二分法>> 1. lambda 匿名函数 lambda 参数: ...
- Spring Boot 启动的时候遇到 java.lang.ClassNotFoundException: ch.qos.logback.classic.Level
在刚开始接触spring boot的时候,想创建一个Hello World 的project. 但是创建完之后,Run as 'Spring Boot APP'的时候遇到这个错误. Level类存在于 ...
- js获取当地时间并且拼接时间格式的三种方式
js获取当地时间并且拼接时间格式,在stackoverflow上有人在问,查了资料,各种方法将时间格式改成任意自己想要的样式. 1. var date = new Date(+new Date()+8 ...