温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

python实现名片管理系统项目

发布时间:2020-08-20 20:42:12 来源:脚本之家 阅读:173 作者:虐猫狂魔薛定谔 栏目:开发技术

名片管理系统,供大家参考,具体内容如下

环境要求:linux系统、python2.x或python3.x
资源地址:GitHub地址

写在前面的话:笔者之前在初学C/C++时,都曾写过类似的管理系统。这次使用Python来书写这个管理系统,深刻地感受到python对程序员的友好。如果使用C来实现,必然需要手写一下链表;而使用C++,显然需要使用STL中的vector或array以及map,语法都稍稍有些复杂。

基础功能

1.循环显示主菜单,显示命令提示。

python实现名片管理系统项目

2.可以通过输入命令来选择新建名片、显示所有名片、搜索名片。当搜索到名片时,可以对其进行删改。

3.附加功能。对数据进行序列化,并且写入文件。

代码分析

一.程序入口cards_main.py

#! /usr/bin/python
import cards_tools
 
while True:
  cards_tools.show_menu()
  action_str = input("请下指令,主人\n")
  print("你的选项是 [%s]" % action_str)
  if action_str in ["1", "2", "3"]:
    if action_str == "1":
      cards_tools.new_card()
    elif action_str == "2":
      cards_tools.show_all()
    elif action_str == "3":
      cards_tools.search_card()
  elif action_str == "0":
    print("寨见了哟~主人sama")
    break
  else:
    print("还不会鸭,请多调教")

1.这段代码开头shebang(#!)后标注了解释器,可以通过./cards_main.py来执行本段代码。如果执行ln -s  cards_main.py /usr/bin/cards, 就可以在终端中用“cards”命令呼出这个简易的名片存储系统。
2.这个程序使用死循环的方式维持主程序的运行,日后如果想增加上传数据等功能时,可以使用多线程、协程等来增加一个并发,来实现。
3.通过判断用户输入,分别调用不同的函数。实现了解耦合。

二.命令提示、新增名片、显示名片

这部分代码没什么好说的,就不多赘述。需要注意的时,在文件开头,定义了个card_list的全局空列表。

card_list = []
 
 
def show_menu():
  print("*" * 50)
  print("主人,让我做点什么鸭:")
  print("1.新建名片")
  print("2.显示全部")
  print("3.搜索名片")
  print("")
  print("0.退出系统")
  print("*" * 50)
 
 
def new_card():
  print("新建名片")
  print("-" * 50)
  name_str = input("输入姓名:")
  phone_str = input("输入手机号:")
  qq_str = input("输入QQ:")
  email_str = input("输入邮箱:")
 
  card_dict = {
    "name": name_str,
    "phone": phone_str,
    "qq": qq_str,
    "email": email_str
  }
  card_list.append(card_dict)
  print("我记下%s咯!" % name_str)
 
 
def show_all():
  if card_list == []:
    print("还没有名片哟,告诉我几个叭~")
    return
  else:
    print("显示全部名片")
    print("-" * 50)
    for name in ["姓名", "电话", "QQ", "邮箱"]:
      print(name, end="\t\t")
    print("")
    print("=" * 50)
    for card_dict in card_list:
      print("%s\t\t%s\t\t%s\t\t%s\t\t" %
         (card_dict["name"],
          card_dict["phone"],
          card_dict["qq"],
          card_dict["email"]))

三、搜索名片

先贴代码

def search_card():
  print("找寻名片")
  print("-" * 50)
  search_name = input("查谁咧?")
  for card_dict in card_list:
    if card_dict["name"] == search_name:
      for name in ["姓名", "电话", "QQ", "邮箱"]:
        print(name, end="\t\t")
      print("")
      print("=" * 50)
      print("%s\t\t%s\t\t%s\t\t%s\t\t" %
         (card_dict["name"],
          card_dict["phone"],
          card_dict["qq"],
          card_dict["email"]))
      deal_card(card_dict)
      break
  else:
    print("母鸡呀!")
 
 
def deal_card(found_dict):
  """
  处理查找到的名片
  :param found_dict:传递找到的字典
  :return:
  """
  action_str = input("我做啥咧 "
            "[1]修改 [2]删除 [0]返回")
  if action_str == "1":
    found_dict["name"] = input_card_info(found_dict["name"], "姓名[回车不修改]:")
    found_dict["phone"] = input_card_info(found_dict["phone"], "手机号[回车不修改]:")
    found_dict["qq"] = input_card_info(found_dict["qq"], "QQ[回车不修改]:")
    found_dict["email"] = input_card_info(found_dict["email"], "邮箱[回车不修改]:")
    print("修改完成")
  elif action_str == "2":
    card_list.remove(found_dict)
    print("吼,木有了")
  else:
    return
 
 
def input_card_info(dict_value, tip_message):
  """
  输入名片信息
  :param dict_value:字典原有值 
  :param tip_message: 输入提示文字
  :return: 如果用户输入了内容,则返回内容;否则返回原有值
  """
  result_str = input(tip_message)
  if len(result_str) > 0:
    return result_str
  else:
    return dict_value

1.传递存储搜索到的字典,对列表进行修改。

2.为了让用户可以选择用回车,避免需要重新输入不需先修该的键值对儿,对内置函数input进行了封装。

代码不足

这段个玩具项目存在严重问题,其一数据都活在内存之中,完全可以通过序列化的方式将字典存储在文件中,甚至可以使用md5对数据进行加密。

使用for循环使得效率低下、功能单一,完全可以使用多线程来增添新功能,不过鉴于本代码只是个玩具,就不实现了。

可选手段

使用最基本的python列表真的时最好的方式吗?列表的数据结构实际上是队列,由于名片对于顺序要求不大,大可以使用C++的STL中unorder_map之类数据结构来存储数据信息。

另外使用字典并非唯一手段,C/C++、Go中的结构体,或是使用类来封装数据,无疑都是可行的。在类中可以添加诸如打印函数等,简化程序,在C++中可以重载流运算符<<。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持亿速云。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI