python新手之字典增删改查
一、字典的定义
city_list = { 'beijin':"北京",'shanghai':"上海" }
print(city_list)
二、字典添加一个元素
city_list['wuhan'] = "武汉" 三、字典修改一个元素
city_list['beijin'] = "武汉" 四、字典删除
1、删除某个键值
city_list.pop("beijin")
print(city_list)
2、随机删除某个一个元素
city_list.popitem() 3、删除所有的元素
city_list.clear()
4、删除一个值
del city_list['beijin']
五、字典的查询
print(city_list['shanghai'])
print(city_list.get('shanghai'))
六、字典的循环遍历
1、方式一:
for key in city_list :
print(key,city_list[key]) 2、方式二:
for key in city_list.keys() :
print(key, city_list[key]) 3、方式三、值遍历
for value in city_list.values() :
print(value) 4、方式四 字典遍历(数量较大时候转化需要时间,建议使用1、2、3)
for it in city_list.items() :
print(it) for key,value in city_list.items() :
print(key,value)
七、字典的其他的函数的使用:
1、fromkeys 初始化一个字典
test = dict.fromkeys('1,2,3',["aa","bb","cc"])
print (test)
2、update 函数合并两个字典,有重复部分更新字典二的值
test = city_list.update(city_list2)
print(city_list) 3、setdefault 有值时候不改变,无值时候添加一个值
city_list2.setdefault('wuhan','武汉')
print(city_list2)
八、字典和列表的区别:
1、字典是无序的,数组是有序的。
2、字典是通过key进行查找,列表是通过键值查找
3、查询算法的复杂度不一样,list 算法复杂度为O(n),字典dict算法复杂度为O(1)
4、占用内存不一样,dict 占用内存是list1.5 九、多级字典使用
# Author : xiajinqi
city_list = {
'北京' : {
'昌平' : ["金山","百度"],
'朝阳' : ["oldboy"]
},
'深圳' : {
'南山区' : ['友金所','金蝶','腾讯','中兴'],
'罗湖区' : ['用友','海颐'],
'宝安区' : ['中国证券','天下第一']
},
'广州' : {
'天河区' : ['天河公园'],
'越秀区': ['越秀公园']
}
}
#多级字典的遍历
for i in city_list :
for j in city_list['北京'] :
print(j)
作业题目一:
手机通讯录实现增加联系人、删除联系人、查询联系人。
脚本:
# Author : xiajinqi
#需求定义一个通讯录实现增加删除查询联系人
phone_address_book = {'xiajinqi':'18125012733','wuwang':'18125012788'}
while 1 :
print(
'''
----欢迎登录手机通讯录首页-----
1、查询联系人手机号码
2、增加一个联系人或者修改一个联系人
3、删除一个联系人
4、显示当前所有联系人
'''
)
user_choose = input("choose :")
if user_choose.isdigit() :
user_choose = int(user_choose)
else :
print("输入的不是一个数字,请重新选择 usage;1")
continue
if user_choose > 4 or user_choose < 1 :
print("输入的值必须要在1和3之间")
continue
if user_choose == 1 :
name = input("请输入要查找的名字: ")
# 通过键值查找联系人手机号码
if name in phone_address_book :
phone = phone_address_book.get(name)
print("名字:%s,手机号码:%s" %(name,phone))
else :
print("你输入的名字在通讯录不存在")
continue
elif user_choose == 2 :
name = input("请输入要修改或者添加人员的名字: ")
phone = input("请输入手机号码:")
phone_address_book [name] = phone
elif user_choose == 3 :
name = input("请输入要删除人员的名字: ")
phone_address_book.pop(name)
elif user_choose == 4 :
for key in phone_address_book.keys() :
print("名字:%s,手机号码:%s" %(key,phone_address_book[key]))
print("当前联系人总数 %s" % (len(phone_address_book)))
else :
print("输入错误,重新选择输入")
作业题目二:
#!/usr/bin/python #三级菜单,实现
################################################
# Task Name: 三级菜单 #
# Description:打印省、市、县三级菜单 #
# 可返回上一级 #
# 可随时退出程序 #
# ----------------------------------------------#
# Author:xiajinqi # city_list = {
'guangzhou':{
'guangzhou':['越秀','天河'],
'shenzhen':['南山区','保安区','罗湖区']
},
'hubei' :{
'wuhan':['武昌区','洪山区','江岸区'],
'huanggang':['麻城','罗田']
}
} province = list(city_list.keys()) #
while 1 :
print(" 省 ".center(50,'*'))
for pro in province :
print(province.index(pro)+1,pro)
user_choose = input("一级菜单,请选择>>>")
if user_choose.isdigit() :
user_choose = int(user_choose)
if user_choose > 0 and user_choose <= len(province) :
pro_name = province[user_choose-1]
city = list(city_list[pro_name].keys())
while 1 :
print(" 市 ".center(50, '*'))
for ct in city :
print(city.index(ct)+1,ct)
city_choose = input("二级菜单,请选择>>>")
if city_choose.isdigit():
city_choose = int(city_choose)
if city_choose > 0 and city_choose <= len(city) :
city_name = city[city_choose -1]
town= city_list[pro_name][city_name]
while 1 :
print(" 区 ".center(50, '*'))
for tn in town:
print(town.index(tn) +1,tn)
town_choose=input("三级菜单,请选择>>>")
if town_choose == 'b' :
break
elif town_choose =='QUIT' :
exit()
else :
print("已经是最底层菜单")
else :
print("选择错误,请重新输入")
continue elif city_choose == 'b':
print("回退")
break
elif city_choose =='QUIT' :
exit()
else :
print("输入错误,请重新输入")
else :
print("输入错误,请重新输入")
elif user_choose == 'QUIT' :
exit()
else :
print("输入不合法")
continue
python新手之字典增删改查的更多相关文章
- python操作mysql数据库增删改查的dbutils实例
python操作mysql数据库增删改查的dbutils实例 # 数据库配置文件 # cat gconf.py #encoding=utf-8 import json # json里面的字典不能用单引 ...
- python 全栈开发,Day5(字典,增删改查,其他操作方法)
一.字典 字典是python中唯一的映射类型,采用键值对(key-value)的形式存储数据.存储大量的数据,是关系型数据,查询数据快. 列表是从头遍历到尾字典使用二分查找 二分查找也称折半查找(Bi ...
- python学习(list增删改查、及常用方法)
1.Python多条件判断: 多条件判断if: passelse: pass循环 while for i = 0 while i > 1: print('hello') else: print( ...
- Python之注册表增删改查(干货)
在Windows平台下,对注册表的增删改查的需求比较多,微软提供了很多用于访问,修改注册表等的API,我们可以使用诸如bat,或者C++等各种方式去访问修改注册表.无所不能的python下如何完成这些 ...
- Python实现mysql数据库增删改查
利用python操作mysql数据库用法简单,环境配置容易,本文将实现对库增.删.改.查的简易封装! 1. 环境配置 安装第三方包 ,导入模块 mysql.connector pip inst ...
- DAY4(python)打印字符串以及增删改查
用while循环打印字符串 #if i in s: # print ( i ) s='nanfjkhndaol' index = 0 while 1 : print (s[index]) index+ ...
- Python中列表、元组、字典增删改查基本区别
1.定义: 列表:num = ["a","b"."c"] ##定义后可增删改查 元组:num = ("a"," ...
- python 基础 字典 增删改查
content = {"name":"wd","pc":{"phone":111111,"age": ...
- Python对数据库的增删改查
#!/usr/bin/env python import MySQLdb DATABASE_NAME = 'hero' class HeroDB: # init class and ...
随机推荐
- 【jQuery】jQuery中的事件捕获与事件冒泡
在介绍之前,先说一下JavaScript中的事件流概念.事件流描述的是从页面中接受事件的顺序. 一.事件冒泡( Event Bubbling) IE 的事件流叫做事件冒泡,即 ...
- 打通 Spark 系统运行内幕机制循环流程
本课主题 打通 Spark 系统运行内幕机制循环流程 引言 通过 DAGScheduelr 面向整个 Job,然后划分成不同的 Stage,Stage 是从后往前划分的,执行的时候是從前往后执行的,每 ...
- 工作好搭档(一):松林 SL-B3 人体工学椅
本人从事码农这行职业,已经整整十年零九天,十年一觉如旧梦,仿佛昨天还在SARS. 2008年,我累到腰痛,脖子痛,怎么休息也不见好,去中医院检查,医生诊断,坐的太久,坐姿不对,运动少,轻度颈椎,腰肌劳 ...
- copy "xxxxx\xx.dll xxxxxxx\ ” 已退出,代码为1 错误解决方法
右键=>属性=>生成事件里面,查看预先生成事件命令行和后期生成事件命令行,查看复制的Dll是否存在已经路径是否正确
- OpenXml操作Excel
要使用OpenXml首先要下载最新的Open XML Format SDK 2.0.具体的导入openxml的dll,去网上搜,很多 1.我个人写的XmlHelp类 using System; usi ...
- Linux 查看所有登录用户的操作历史
在linux系统的环境下,不管是root用户还是其它的用户只有登陆系统后用进入操作我们都可以通过命令history来查看历史记录,可是假如一台服务器多人登陆,一天因为某人误操作了删除了重要的数据.这时 ...
- 「hihocoder1413 Rikka with String」
题目 哈哈哈哈哈哈哈哈哈哈我还没自闭 好像前后调了两天了 哈哈哈哈哈哈哈哈哈哈我还没自闭 这道题就是给定一个小写字母串,回答分别把每个位置上的字符替换为\(#\)后的本质不同的子串数 首先就是跨过这个 ...
- 集合HashMap和HashSet中迭代器的使用
package setTest; import java.util.HashMap;import java.util.HashSet;import java.util.Iterator;import ...
- 二十四、详述 IntelliJ IDEA 中自动生成 serialVersionUID 的方法
当我们用 IntelliJ IDEA 编写类并实现 Serializable(序列化)接口的时候,可能会遇到这样一个问题,那就是: 无法自动生成serialVersionUID. 而serialVer ...
- 使用Fiddler做抓包分析
转载:http://blog.csdn.net/ohmygirl/article/details/17849983 Fiddler抓取HTTP请求. 抓包是Fiddler的最基本的应用,以本博客为例, ...