欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Linux下python制作名片示例

 更新時間:2018年07月20日 09:00:28   作者:Le_Anny  
這篇文章主要介紹了Linux下python制作名片示例的相關資料,需要的朋友可以參考下

建立cards_main文件:

# _*_ coding:utf-8 _*_
"""
file: cards_main.py
date: 2018-07-18 19:47
author: jiong
desc:

"""
import cards_tools
#無限循環(huán),由用戶主動決定什么時候退出
while True:
#TODO注釋,用于標記需要去做的工作

 cards_tools.show_menu()

 action_str = raw_input("請選擇希望執(zhí)行的操作: ")
 print("你選擇的操作是 %s" % action_str)
 #1,2,3針對名片的操作
 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()

 #0退出系統(tǒng)
 elif action_str == "0":
  print("歡迎再次使用【名片管理系統(tǒng)】:")

  break
  #如果在開發(fā)程序時,不希望立刻編寫分支內(nèi)部的代碼
  #可以使用pass關鍵字,表示一個占位符,能夠保證程序的代碼結構正確
  #運行程序時,pass關鍵字不會執(zhí)行任何操作
 else:
  print("輸入錯誤,請重新輸入:")

建立cards_tools文件

# _*_ coding:utf-8 _*_
"""
file: cards_tools.py
date: 2018-07-18 19:47
author: jiong
desc:

"""
card_list = []

def show_menu():
 """顯示菜單"""
 print '*' * 50
 print '歡迎使用【名片管理系統(tǒng)】'
 print ''
 print '1.新增名片'
 print '2.顯示全部'
 print '3.搜索名片'
 print '0.退出系統(tǒng)'
 print '*' * 50

def new_card():
 """新增名片"""
 print '-' * 50
 print '新增名片'
 # 1.提示用戶輸入名片的詳細信息
 name_str = raw_input('請輸入姓名:')
 phone_str = raw_input('請輸入電話:')
 qq_str = raw_input('請輸入QQ:')
 email_str = raw_input('請輸入郵箱:')

 # 2.使用用戶輸入的信息建立一個名片字典
 card_dict = {'name_str': name_str,
     'phone_str': phone_str,
     'qq_str': qq_str,
     'email_str': email_str}

 # 3.將名片字典添加到列表中
 card_list.append(card_dict) # 把一個字典追加到一個列表中
 print card_list
 # 4.提示用戶添加成功
 print '添加%s 的名片成功' % name_str

def show_all():
 """顯示所有名片"""
 print '-' * 50
 print '顯示所有名片'

 # 判斷是否存在名片記錄,如果沒有,提示用戶并且返回
 if len(card_list) == 0:
  print '當前沒有任何的名片記錄,請使用新增功能添加名片'
  # return 可以返回一個函數(shù)的執(zhí)行結果
  # 下方的代碼不會被執(zhí)行
  # 如果return后面沒有任何的內(nèi)容,表示會返回到調用函數(shù)的位置
  # 并且不返回任何結果
  return
 # 打印表頭
 for name in ["姓名", "電話", "QQ", "郵箱"]:
  print name,
 print ''
 # 打印分隔線
 print '=' * 50

 # 遍歷名片列表依次輸出字典信息
 for card_dict in card_list:
  # print card_dict
  print '%s\t\t%s\t\t%s\t\t%s' % (card_dict['name_str'],
          card_dict['phone_str'],
          card_dict['qq_str'],
          card_dict['email_str'])

def search_card():
 """搜索名片"""
 print '-' * 50
 print '搜索名片'

 # 1.提示用戶輸入要搜索的姓名
 find_name = raw_input('請輸入要搜索的姓名:')
 # 2.遍歷名片列表,查詢要搜索的姓名,如果沒有找到,需要提示用戶
 for card_dict in card_list:
  if card_dict['name_str'] == find_name:
   print '姓名 電話 QQ 郵箱'
   print '=' * 50
   print '%s %s %s %s' % (card_dict['name_str'],
         card_dict['phone_str'],
         card_dict['qq_str'],
         card_dict['email_str'])

   # TODO 針對找到的名片記錄執(zhí)行修改和刪除的操作
   # 在我們的日常編寫程序中,如果一個函數(shù)的代碼太多,閱讀和編寫都是一件困難的事情,而在開發(fā)中,可以針對一個具體獨立的功能來封裝一個函數(shù),由這個函數(shù)來處理具體的操作,這樣就能保證每個函數(shù)中的代碼清晰明了,功能明確
   deal_card(card_dict)
   break

  else:
   print '抱歉,沒有找到%s' % find_name


def deal_card(find_dict):
 print find_dict
 action_str = raw_input('請選擇要執(zhí)行的操作 '
       '[1] 修改 [2] 刪除 :')
 # 替換已經(jīng)存在的鍵值對
 if action_str == '1':
  find_dict['name_str'] = input_card_info(find_dict['name_str'], '姓名:')
  find_dict['phone_str'] = input_card_info(find_dict['phone_str'], '電話:')
  find_dict['qq_str'] = input_card_info(find_dict['qq_str'], 'QQ:')
  find_dict['email_str'] = input_card_info(find_dict['email_str'], '郵箱:')

  print '修改名片成功?。?!'
 elif action_str == '2':

  card_list.remove(find_dict)

  print '刪除名片成功?。?!'

def input_card_info(dict_value, tip_message):


 """

 :param dict_value:字典中原有的值
 :param tip_message:輸入的提示文字
 :return:如果用戶輸入了內(nèi)容,就返回內(nèi)容,負責返回字典中原有的值
 """
 # 1.提示用戶輸入內(nèi)容

 result_str = raw_input(tip_message)
 # 2.針對用戶的輸入進行判斷,如果用戶輸入了內(nèi)容,直接返回結果
 if len(result_str) > 0:
  return result_str
 # 3.如果用戶沒有輸入內(nèi)容,返回‘字典中原有的值'
 else:
  return dict_value

執(zhí)行cards_mian文件:

這里寫圖片描述 

這里寫圖片描述 

這里寫圖片描述

相關文章

  • 解決python selenium3啟動不了firefox的問題

    解決python selenium3啟動不了firefox的問題

    今天小編就為大家分享一篇解決python selenium3啟動不了firefox的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-10-10
  • 一篇文章徹底弄懂Python中的if?__name__?==?__main__

    一篇文章徹底弄懂Python中的if?__name__?==?__main__

    在Python當中如果代碼寫得規(guī)范一些,通常會寫上一句if '__name__'=='__main__:'作為程序的入口,下面這篇文章主要給大家介紹了關于如何通過一篇文章徹底弄懂Python中的if?__name__?==?__main__的相關資料,需要的朋友可以參考下
    2022-12-12
  • python中的循環(huán)語法使用指南

    python中的循環(huán)語法使用指南

    這篇文章主要給大家介紹了關于python中循環(huán)語法使用的相關資料, 循環(huán)語句是Python中的一種基本語句,用于重復執(zhí)行一段代碼。在Python中,循環(huán)語句分為for和while兩種,需要的朋友可以參考下
    2023-08-08
  • Python進制轉換用法詳解

    Python進制轉換用法詳解

    大家好,本篇文章主要講的是Python進制轉換用法詳解,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-01-01
  • python爬蟲泛濫的解決方法詳解

    python爬蟲泛濫的解決方法詳解

    在本篇文章里小編給大家整理了關于python爬蟲泛濫的解決方法詳解內(nèi)容,需要的朋友們可以學習參考下。
    2020-11-11
  • 解決在pycharm運行代碼,調用CMD窗口的命令運行顯示亂碼問題

    解決在pycharm運行代碼,調用CMD窗口的命令運行顯示亂碼問題

    今天小編就為大家分享一篇解決在pycharm運行代碼,調用CMD窗口的命令運行顯示亂碼問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08
  • Tensorflow 多線程設置方式

    Tensorflow 多線程設置方式

    今天小編就為大家分享一篇Tensorflow 多線程設置方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-02-02
  • 使用Python自定義創(chuàng)建的Log日志模塊

    使用Python自定義創(chuàng)建的Log日志模塊

    這篇文章主要介紹了使用Python自定義創(chuàng)建的Log日志模塊,日志文件是用于記錄系統(tǒng)操作事件的文件集合,可分為事件日志和消息日志。具有處理歷史數(shù)據(jù)、診斷問題的追蹤以及理解系統(tǒng)的活動等重要作用,需要的朋友可以參考下
    2023-07-07
  • pytorch GPU和CPU模型相互加載方式

    pytorch GPU和CPU模型相互加載方式

    在PyTorch中,保存和加載模型有兩種主要方式:直接保存整個模型結構加權重,或者只保存模型的參數(shù),直接保存整個模型的方法簡單,但不夠靈活,且可能存在模型結構不一致的風險,推薦的做法是只保存模型參數(shù),這種方法需要在加載前定義與原模型結構相同的模型
    2024-09-09
  • Pycharm?cannot?set?up?a?python?SDK問題的原因及解決方法

    Pycharm?cannot?set?up?a?python?SDK問題的原因及解決方法

    這篇文章主要給大家介紹了關于Pycharm?cannot?set?up?a?python?SDK問題的原因及解決方法,這個問題已經(jīng)不是第一次出現(xiàn)了,所以干脆總結下,需要的朋友可以參考下
    2022-06-06

最新評論