1. import os
  2. user_dic = {
  3. 'username':None,
  4. 'password':None,
  5. 'login':True
  6. }
  7. flag = False
  8.  
  9. name_list = ['id','name','age','phone','job']
  10.  
  11. check_conditions = ['>','<','=','like']
  12. def auth(func):
  13. def wrapper(*args,**kwargs):
  14. with open('user-pwd',encoding='utf-8') as f:
  15. user = eval(f.read())
  16. # print(user)
  17. count = 0
  18. while count<3:
  19. username = input('请输入用户名:').strip()
  20. password = input('请输入密码:').strip()
  21. if user.get(username) and password == user[username]:
  22. user_dic['username'] = username
  23. user_dic['password'] = password
  24. user_dic['login'] = True
  25. ret = func(*args,**kwargs)
  26. return ret
  27. else:
  28. count += 1
  29. if count == 3:
  30. print('由于多次输入,您已经没有输入机会,请重新登陆...')
  31. else:
  32. print('用户名或密码不正确,您还有%s次输入机会,请重新输入...' % (2 - count))
  33. return wrapper
  34.  
  35. def get_last_id():
  36. '''
  37. 此函数是获取id表中的id
  38. :return: 返回值是最后的id,如果第一次给员工信息表添加信息,id为0
  39. '''
  40. with open('id表',encoding='utf-8') as f:
  41. list_id = f.read()
  42. return int(list_id) if list_id else 0
  43.  
  44. def add():
  45. '''
  46. 此函数是为员工信息表添加新的数据,关键点再添加新数据后id会随着添加信息而改变
  47. :return: None
  48. '''
  49. old_last_id = get_last_id()
  50. input_infor = input('请按照下列格式输入信息:'
  51. '姓名,年龄,电话,职业').strip()
  52. new_last_id = str(int(old_last_id)+1)
  53. add_infor = new_last_id + ','+ input_infor
  54. with open('员工信息表',encoding='utf-8',mode='a') as f2:
  55. #次三元运算是判断员工信息表中如果是第一次添加内容则无需换行,否则需要换行。
  56. f2.write(add_infor) if old_last_id == 0 else f2.write('\n'+ add_infor)
  57. print('您已成功添加,请继续操作')
  58. with open('id表',encoding='utf-8',mode='w') as f3:
  59. f3.write(new_last_id)
  60.  
  61. def pop():
  62. '''
  63. 此函数的功能是删除员工信息表中的数据,关键点:
  64. flag的设置是因为我们在打开员工信息表的过程中不能删除此员工信息表。
  65. 所以设置标志位,等操作完成之后,再删除原文件,重新命名新文件。
  66. :return:
  67. '''
  68. pop_id = input('请输入你想删除的信息的id:')
  69. with open('员工信息表',encoding = 'utf-8') as f:
  70. for line in f:
  71. line_list = line.strip().split(',')
  72. if pop_id == line_list[0]:
  73. global flag
  74. flag = True
  75. with open('员工信息表',encoding='utf-8') as f1,\
  76. open('员工信息表.bak',encoding='utf-8',mode='a') as f2:
  77. for line1 in f1:
  78. f2.write(line1) if pop_id != line1.strip().split(',')[0] else f2.write('')
  79. break
  80. else:
  81. print('没有您输入id,请重新输入...')
  82. if flag:
  83. os.remove('员工信息表')
  84. os.rename('员工信息表.bak','员工信息表')
  85.  
  86. def update():
  87. '''
  88. 此函数的功能修改员工信息
  89. 语法:set 列名 = ’新的值‘ where 条件
  90. 先用where查找对应人的信息,再使用set来修改列名对应的值为'新的值'
  91. 关键点:
  92. check_conditions,name_list 这两个列表的运用
  93. name_list 为员工信息表的列表 , 'id', 'name', 'age', 'phone', 'job' 索引与员工信息表每行信息的每列一一对应。
  94. 思路:
  95. 1,先通过where 分割,得到content (如:set name = 顾清秋),cond (如:id<3)
  96. 2,循环check_conditions(>,<,=,like) 通过条件分割得到的是:name 是 id , key 是 >,cond 是3
  97. 3,对content进行操作,得到要修改的列名:column_name,要修改的值 uodate_value
  98. 4,文件改的思想,修改文件,需要对原文件进行读取,再写入新文件,然后将原文件删除重命名新文件。
  99. 5,关键点:check_dict这是一个if 条件的字典,这样设置是因为不管条件为<>=或like
  100. 它们只要满足条件,下面进行的操作是一样的,所以只是条件不同,所以可以根据
  101. key的不同,执行check_list不痛的条件,然后进行相同的内容即可。
  102. :return:
  103. '''
  104. pass
  105.  
  106. def check():
  107. '''
  108. 此函数是查询功能:
  109. 支持三种语法:
  110. select 列名1,列名2,...where 列名条件
  111. 支持大于小于等于,也可模糊查询
  112. 示例:
  113. check_infor = select name,age where age>22
  114. check_infor = select * where job = IT
  115. check_infor = select * wherr phone like 133
  116. 关键点:
  117. check_conditions,name_list 这两个列表的运用
  118. :return:
  119. '''
  120. try:
  121. check_infor = input('请输入查询语句:').strip()
  122. content,condition = check_infor.split('where') # ['select name, age','age>22']
  123. if 'select' in content:
  124. for key in check_conditions: # ['>', '<', '=', 'like']
  125. if key in condition:
  126. index_check_conditions = check_conditions.index(key)
  127. name,cond = condition.strip().split(key) # age ,22
  128. # content 为 'select name,id,或'select * ''
  129. # name 是 where 后面的第一个关键字
  130. # key 是比较运算符
  131. # cond 是 实际需要比较的关键字
  132. # 例如:where id > 3 name是id,key是> ,cond 是 3
  133. content = content.split('select')[1] # 'name,age'
  134. with open('员工信息表',encoding='utf-8') as f:
  135. for line in f:
  136. if line.strip(): # 保证每行不是空
  137. line_list = [i.strip() for i in line.strip().replace(',',',').split(',')]
  138. # 上面是为了替换掉中文的逗号,
  139. index= name_list.index(name.strip())
  140. # index 查询条件的索引没比如你的查询条件是 select * where id > 3
  141. # name 就是 id 求出的 index 就是id 在 name_list 中的索引,
  142. # 也是id 在name_list 列表中的索引。
  143. check_dict= {
  144. 0:line_list[index] > cond,
  145. 1:line_list[index] < cond,
  146. 2:line_list[index].strip() == cond.strip(),
  147. 3:cond.strip() in line_list[index].strip()
  148. }
  149. if check_dict[index_check_conditions]:
  150. if content.strip() == '*':
  151. print(line.strip())
  152. else:
  153. if ',' in content.strip():
  154. select_name_list = content.strip().split(',') # ['name','age']
  155. select_name_list = [i for i in select_name_list if i != '']
  156. str1 = ''
  157. for names in select_name_list:
  158. name_index = name_list.index(names.strip()) # 找出 在name_list中的索引,
  159. str1 = str1 + line_list[name_index] + ','
  160. print(str1)
  161. else:
  162. print(line_list[name_list.index(content)])
  163. break
  164. else:
  165. print('你输入的不正确,请重新输入...')
  166. else:
  167. print('您没有输入select语句或者输入有误,请重新输入...')
  168. except Exception:
  169. print('你输入的查询语句有误,请重新输入...')
  170.  
  171. def loginout():
  172. print('感谢您登陆员工内部系统')
  173. user_dic['login'] = False
  174.  
  175. @auth
  176. def main():
  177. menu = """
  178. 欢迎%s用户登陆内部员工系统,请进行选择:
  179. 选项 1,增加员工信息
  180. 选项 2,删除员工信息
  181. 选项 3,更改员工信息
  182. 选项 4,查询员工信息
  183. 选项 5,退出内部员工系统
  184. """ % (user_dic['username'])
  185.  
  186. choice_dict = {
  187. '':add,
  188. '':pop,
  189. '':update,
  190. '':check,
  191. '':loginout
  192. }
  193. while user_dic['login']:
  194. print(menu)
  195. option = input('请输入你的选项:').strip()
  196. if option in choice_dict:
  197. choice_dict[option]()
  198. else:
  199. print('请输入正确的选项')
  200.  
  201. if __name__ == '__main__':
  202. main()

python's sixteenth day for me 员工信息表的更多相关文章

  1. python练习程序_员工信息表_基本实例

    python实现增删改查操作员工信息文件,可进行模糊查询: http://edu.51cto.com/lesson/id-13276.html http://edu.51cto.com/lesson/ ...

  2. python作业员工信息表程序(第四周)

    作业需求: 1. 员工信息表程序,实现增删改查操作: 2. 可进行模糊查询,语法至少支持下面3种: select name,age from staff_table where age > 22 ...

  3. day12 python作业:员工信息表

    作业要求: 周末大作业:实现员工信息表文件存储格式如下:id,name,age,phone,job1,Alex,22,13651054608,IT2,Egon,23,13304320533,Tearc ...

  4. python练习题-员工信息表

    周末大作业:实现员工信息表文件存储格式如下:id,name,age,phone,job1,Alex,22,13651054608,IT2,Egon,23,13304320533,Tearcher3,n ...

  5. python基础之员工信息表作业

    周末大礼包 文件存储格式如下: id, name, age, phone, job 1, Alex, 22, 13651054608, IT 2, Egon, 23, 13304320533, Tea ...

  6. python-查询员工信息表

    python查询员工信息表 基本要求: 用户可以模糊查询员工信息 显示匹配了多少条,匹配字符需要高亮显示 代码: #!/usr/env python #coding:utf-8 import time ...

  7. python-打印简单公司员工信息表

    python-打印简单公司员工信息表 要求,输入name不为空,输入次数最多3次,3次后跳出程序: 知识点: raw_input str转int whil if elif else continue ...

  8. python3 员工信息表

    这是最后一条NLP了......来吧 十二,动机和情绪总不会错,只是行为没有效果而已 动机在潜意识里,总是正面的.潜意识从来不会伤害自己,只会误会的以为某行为可以满足该动机,而又不知道有其他做法的可能 ...

  9. 无废话ExtJs 入门教程十五[员工信息表Demo:AddUser]

    无废话ExtJs 入门教程十五[员工信息表Demo:AddUser] extjs技术交流,欢迎加群(201926085) 前面我们共介绍过10种表单组件,这些组件是我们在开发过程中最经常用到的,所以一 ...

随机推荐

  1. 【转】Java设计模式-单例模式详解

    原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/6510196.html 所谓单例,指的就是单实例,有且仅有一个类实例,这个单例不应该由人来控 ...

  2. Educational Codeforces Round 22E

    给你n和k,n个数,每个数范围1e5,m次查询,每次查询区间(l,r),在区间中的每个数,如果超过k次只算k次,否则算原来的次数,求总次数,强制在线 解法:线段树维护区间中每个数经过k次到达的点pos ...

  3. Cassandra key说明——Cassandra 整体数据可以理解成一个巨大的嵌套的Map Map<RowKey, SortedMap<ColumnKey, ColumnValue>>

    Cassandra之中一共包含下面5种Key: Primary Key Partition Key Composite Key Compound Key Clustering Key 首先,Prima ...

  4. [转载]JAVA获取word表格中数据的方案

    上一个项目的开发中需要实现从word中读取表格数据的功能,在JAVA社区搜索了很多资料,终于找到了两个相对最佳的方案,因为也得到了不少网友们的帮助,所以不敢独自享用,在此做一个分享. 两个方案分别是: ...

  5. CentOS7 安装ifconfig

    As we all know, “ifconfig” command is used to configure a network interfaces in GNU/Linux systems. I ...

  6. maven pox.xml文件报错解决办法 亲测可以

    问题1 由于maven下载依赖包失败导致一些文件没完全下载下来,形成了lastUpdated结尾的文件存放在本地仓库中(我是默认地址:C:\Users\Administrator\.m2\reposi ...

  7. R语言-数据类型与运算符

    一.在线安装包 install.packages(package_name) 二.查看变量 ls() 三.删除变量 rm() 四.变量类型 元数据类型:字符,整形,数字,虚数,BOOL 向量:vec= ...

  8. 开源项目Universal Image Loader for Android 说明文档 (1) 简介

     When developing applications for Android, one often facesthe problem of displaying some graphical ...

  9. WPS烦人问题

    [原]彻底解决WPS弹出热点广告.WPS购物图标的办法 搜索wpsnotify.exe,删除并新建同名文件. 搜索updateself.exe,删除并新建同名文件. 关闭我的WPS,搜索khomepa ...

  10. poj 3517

    题目链接  http://poj.org/problem?id=3517 题意        约瑟夫环  要求最后删掉的那个人是谁: 方法        理解递推公式就行了  考虑这样一组数据  k ...