路飞学城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 ...
随机推荐
- socket代码(简单)
SERVER: #!/usr/bin/python # -*- coding: utf-8 -*- import socket import time s = socket.socket(socket ...
- sqlhelper 数据库帮助操作类
数据库帮助类 using System; using System.Collections.Generic; using System.Linq; using System.Text; using S ...
- 利用after和before伪元素在文字两边写横线
示例: 代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...
- [CodeForces]1006F Xor Path
双向搜索. 水div3的时候最后一道题由于C题死活看不懂题 来不及做F了Orz.. 因为n,m是20,双向搜索一下,求个到中间的Xor值的方案,统计一下即可. 时间复杂度\(O(2^{21})\) 好 ...
- Centos 6/7 忘记root密码处理方法
1. centos 6.x 重置root密码 开机按esc 到下图 按 e 键进入编辑模式,通常选择第二项后按 e 键编辑此项 进入该编辑模式后,在quiet后面输入 simple 或者 1 然后回 ...
- windows关于定时执行的php脚本
根据业务需求,需要服务器每天定时执行一些脚本,如后台提交数据,定时处理数据库等. 最初的思路是在某个控制器里写好方法,加入code验证,定期的用计划任务去访问.由于window计划任务这方面比较low ...
- tp 在Nginx上各种404
对于ThinkPHP的URL访问路劲如:http://域名/index.php/Index/BlogTest/read,原先的Nginx的是不支持的pathinfo路劲的,导致你在thinkPHP5上 ...
- 省赛i题/求1~n内全部数对(x,y),满足最大公约数是质数的对数
求1~n内全部数对(x,y),gcd(x,y)=质数,的对数. 思路:用f[n]求出,含n的对数.最后用sum[n]求和. 对于gcd(x,y)=a(设x<=y,a是质数),则必有gcd(x/a ...
- iptables 防火墙 只允许某IP访问某端口、访问特定网站
iptables 防火墙 只允许某IP访问某端口.访问特定网站 1.先备份iptables /var/tmp 需要开80端口,指定IP和局域网 下面三行的意思: 先关闭所有的80端口 开启ip段192 ...
- BZOJ 2301 莫比乌斯函数+分块
思路: 同BZOJ1101 就是加个容斥 - http://blog.csdn.net/qq_31785871/article/details/54340241 //By SiriusRen #inc ...