路飞学城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 ...
随机推荐
- Java之Foreach语句
Foreach是for语句的特殊简化版本,但任何时候的foreach语句都可以改写成for语句.Foreach语句在遍历数组等方面为程序员提供了很大的方便 语法如下: For(元素变量 x:遍历对象o ...
- Android回炉系列之四大组件之首Activity
有段时间没有认认真真研习过android了,android毕竟是我进这个软件开发圈子接触的第一门技术,android已经成了口头禅之类的东西了.当初学习android的时候大都是草草了 ...
- SASS概览
1.安装: sass需要使用ruby,首先安装ruby,之后: gem install sass 编译: sass input.scss output.css 2.快速入门: 变量: .scss 变量 ...
- 嵌入式平台选择:树莓派 or BeagleBone Black(BBB)
原文链接: Michael Leonard 翻译: 极客范- 小道空空 译文链接: http://www.geekfan.net/5246/ 嵌入式平台选择:树莓派 or BeagleBone Bla ...
- 模板 FFT 快速傅里叶变换
FFT模板,原理不难,优质讲解很多,但证明很难看太不懂 这模板题在bzoj竟然是土豪题,服了 #include <cmath> #include <cstdio> #inclu ...
- ELK搭建和部署-----(上半部分)
本实验基于centos7安装部署操作步骤如下: 1.首先准备两台centos7系统,IP地址自行定义. 2.先在服务器上安装时间同步中间件为chronyc 3.并启动命令为systemctl star ...
- oracle 用户解锁和修改用户密码
1.安装教程参看:https://jingyan.baidu.com/article/3c48dd34be2a32e10be35881.html 2.用户解锁 --> 运行cmd --> ...
- PHP中对hmac_sha1签名算法的实现方法
最近研究网宿云文档API,其中用到了一种叫hmac_sha1的签名算法: HMAC-SHA1: HMAC是哈希运算消息认证码 (Hash-based Message Authentication Co ...
- ftp for linux 配置
曾经配的熟悉的不能再熟悉了的东西,多年不用就忘了. 好真是好记性不如烂笔头.本文假如你已经安装好了, 1,ftp默认是不同意root用户登录的,假设要root用户登录,请例如以下改动:打开/etc/v ...
- c3p0在spring中的配置
在大家的开发和学习其中应该经经常使用到数据库的连接和使用,只是连接 的方式就有非常多种方式了,例如说用最最简单的JDBC 也好,还实用比 较复杂一点的就是数据库连接池.当然还有使用DBCP的连接的,各 ...