main.py 5.3 KB

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