main.py 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155
  1. import pymysql
  2. INSERT_CONTACTER = """
  3. insert into tb_contacter (conname, contel, conemail)
  4. values (%s, %s, %s)
  5. """
  6. DELETE_CONTACTER = """
  7. delete from tb_contacter where conid=%s
  8. """
  9. UPDATE_CONTACTER = """
  10. update tb_contacter set conname=%s, contel=%s, conemail=%s
  11. where conid=%s
  12. """
  13. SELECT_CONTACTERS = """
  14. select conid as id, conname as name, contel as tel, conemail as email
  15. from tb_contacter limit %s offset %s
  16. """
  17. COUNT_CONTACTERS = """
  18. select count(conid) as total from tb_contacter
  19. """
  20. def input_contacter_info():
  21. name = input('姓名: ')
  22. tel = input('手机: ')
  23. email = input('邮箱: ')
  24. return name, tel, email
  25. def add_new_contacter(con):
  26. name, tel, email = input_contacter_info()
  27. try:
  28. with con.cursor() as cursor:
  29. if cursor.execute(INSERT_CONTACTER,
  30. (name, tel, email)) == 1:
  31. print('添加联系人成功!')
  32. except pymysql.MySQLError as err:
  33. print(err)
  34. print('添加联系人失败!')
  35. def delete_contacter(con, contacter_id):
  36. try:
  37. with con.cursor() as cursor:
  38. if cursor.execute(DELETE_CONTACTER, (contacter_id, )) == 1:
  39. print('联系人已经删除!')
  40. except pymysql.MySQLError as err:
  41. print(err)
  42. print('删除联系人失败!')
  43. def edit_contacter_info(con, contacter):
  44. name, tel, email = input_contacter_info()
  45. contacter['name'] = name or contacter['name']
  46. contacter['tel'] = tel or contacter['tel']
  47. contacter['email'] = email or contacter['email']
  48. try:
  49. with con.cursor() as cursor:
  50. if cursor.execute(UPDATE_CONTACTER,
  51. (contacter['name'], contacter['tel'],
  52. contacter['email'], contacter['id'])) == 1:
  53. print('联系人信息已经更新!')
  54. except pymysql.MySQLError as err:
  55. print(err)
  56. print('更新联系人信息失败!')
  57. def show_contacter_detail(con, contacter):
  58. print('姓名:', contacter['name'])
  59. print('手机号:', contacter['tel'])
  60. print('邮箱:', contacter['email'])
  61. choice = input('是否编辑联系人信息?(yes|no)')
  62. if choice == 'yes':
  63. edit_contacter_info(con, contacter)
  64. else:
  65. choice = input('是否删除联系人信息?(yes|no)')
  66. if choice == 'yes':
  67. delete_contacter(con, contacter['id'])
  68. def find_all_contacters(con):
  69. page, size = 1, 5
  70. try:
  71. with con.cursor() as cursor:
  72. cursor.execute(COUNT_CONTACTERS)
  73. total = cursor.fetchone()['total']
  74. while True:
  75. cursor.execute(SELECT_CONTACTERS,
  76. (size, (page - 1) * size))
  77. contacters_list = []
  78. for index, row in enumerate(cursor.fetchall()):
  79. contacters_list.append(row)
  80. print('[%d]: %s' % (index, row['name']))
  81. choice = input('是否查看联系人详情?(yes|no)')
  82. if choice.lower() == 'yes':
  83. index = int(input('请输入编号: '))
  84. if 0 <= index < cursor.rowcount:
  85. show_contacter_detail(con, contacters_list[index])
  86. if page * size < total:
  87. choice = input('继续查看下一页?(yes|no)')
  88. if choice.lower() == 'yes':
  89. page += 1
  90. else:
  91. break
  92. else:
  93. print('没有下一页记录啦!')
  94. break
  95. except pymysql.MySQLError as err:
  96. print(err)
  97. def find_contacters_by_name(con):
  98. pass
  99. def find_contacters(con):
  100. while True:
  101. print('1. 查看所有联系人')
  102. print('2. 搜索联系人')
  103. print('3. 退出查找')
  104. choice = int(input('请输入: '))
  105. if choice == 1:
  106. find_all_contacters(con)
  107. elif choice == 2:
  108. find_contacters_by_name(con)
  109. elif choice == 3:
  110. break
  111. def main():
  112. con = pymysql.connect(host='10.7.185.126', port=3306,
  113. user='root', passwd='123456',
  114. db='contact', charset='utf8',
  115. autocommit=True,
  116. cursorclass=pymysql.cursors.DictCursor)
  117. while True:
  118. print('=====通讯录=====')
  119. print('1. 新建联系人')
  120. print('2. 查找联系人')
  121. print('3. 退出系统')
  122. print('===============')
  123. choice = int(input('请选择: '))
  124. if choice == 1:
  125. add_new_contacter(con)
  126. elif choice == 2:
  127. find_contacters(con)
  128. elif choice == 3:
  129. con.close()
  130. print('谢谢使用, 再见!')
  131. break
  132. if __name__ == '__main__':
  133. main()