【Python025-字典】
一、字典
1、创建和访问字典(字典是大括号表示,字典是映射类型)
语法类型:键:key,值:value,用冒号隔开
---
>>> dict1 = {'李宁':'一切皆有可能','耐克':'just do it','阿迪达斯':'Impossible is nothing','鱼C工作室':'编程改变世界'}
>>> print('鱼C工作室的口号是:',dict1['鱼C工作室']) #dict1['鱼C工作室']):加上的是键
鱼C工作室的口号是: 编程改变世界
2、尝试一下将数据(‘F’:70,'C':67,''h:104,'i':105,'s':115)创建为一个字典并访问‘C’对应的值?
>>> dict1={'F':70,'C':67,'h':104,'i':105,'s':115}
>>> print(dict1['C'])
67
>>>
-----------------------------------------
>>> dict2 = dict((('F', 70), ('i',105), ('s',115), ('h',104), ('C',67)))
>>> dict2['C']
67
>>>
3、创建字典的集中方式:
>>> a = dict(one=1, two=2, three=3)
>>> b = {'one': 1, 'two': 2, 'three': 3}
>>> c = dict(zip(['one', 'two', 'three'], [1, 2, 3]))
>>> d = dict([('two', 2), ('one', 1), ('three', 3)])
>>> e = dict({'three': 3, 'one': 1, 'two': 2})
打印出来的结果都是:{'one': 1, 'two': 2, 'three': 3}
4、字典和字符串的结合:
data = "1000,小甲鱼,男"
MyDict = {}
# 还记得字符串的分割方法吧,别学过就忘啦^_^
(MyDict['id'], MyDict['name'], MyDict['sex']) = data.split(',')
print("ID: " + MyDict['id'])
print("Name: " + MyDict['name'])
print("Sex " + MyDict['sex'])
'''
执行结果:
ID: 1000
Name: 小甲鱼
Sex 男
'''
split()函数:
Python中有split()和os.path.split()两个函数,具体作用如下:
split():拆分字符串。通过制定分隔符对字符串进行切片,并返回分割后的字符串列表(list)。如:split(‘,’)通过,号分隔
os.path.split():按照路径将文件名和路径分隔开
一、函数说明
1、split()函数
语法:str.split(str="",num=string.count())[n]
参数说明:
str:表示分隔符,默认是空格,但是不能为空(‘’)。若字符串中没有分隔符,则把整个字符串作为列表的一个元素
num:表示分隔次数。如果存在参数num,则仅分隔成num+1个子字符串,并且每一个子字符串可以赋给新的变量
[n]:表示选择第几个切片
注意:当使用空格作为分隔符时,对于中间为空的项会自动忽略
2、os.path.split()函数:
语法:os.path.split('PATH')
参数说明:
1、PATH指一个文件的全路径作为参数
2、如果给出的是一个目录和文件名,则输出路径和文件名
3、如果给出的是一个目录名,则输出路径和为空的文件名
二、实例
1、常用实例
u = "www.yizhibo.com"
#使用默认分隔符
>>> u.split()
['www.yizhibo.com']
#使用'.'分隔符,并且分隔1次
>>> u.split('.',1)
['www', 'yizhibo.com']
#分隔两次
>>> u.split('.',2)
['www', 'yizhibo', 'com']
#分隔2次,并取序列为1的项
>>> u.split('.',2)[1]
'yizhibo'
#分隔最多次(实际与不加num参数相同)
>>> u.split('.',-1)
['www', 'yizhibo', 'com']
#分隔两次,并把分割后的三部分保存到三个文件
>>> u1,u2,u3=u.split('.',2)
>>> u1
'www'
>>> u2
'yizhibo'
>>> u3
'com'
2、去掉换行符
>>> c = '''say
hello
baby'''
>>> c
'say\nhello\nbaby'
>>> c.split('\n')
['say', 'hello', 'baby']
3、一个超级好的例子:
>>> str="hello boy<[www.doiido.com]>byebye"
>>> str.split("[")[1].split("]")[0]
'www.doiido.com'
>>> str.split('[')[1].split(']')[0]
'www.doiido.com'
>>> str.split("[")[1].split("]")[0].split('.')
['www', 'doiido', 'com']
三、动手题:
1、尝试利用字典的特性编写一个 通讯录程序,功能如图:

具体代码:
print("""
|--- 欢迎进入通讯录程序 ---|
|--- 1:查询联系人资料 ---|
|--- 2:插入新的联系人 ---|
|--- 3:删除已有联系人 ---|
|--- 4:退出通讯录程序 ---|""")
key = 5
dict1 = {'尘封':'18088888888'}
while key!=4:
key = int(input('请输入相关的指令代码:'))
if key == 1:
temp = input("请输入联系人的姓名:")
if temp in dict1:
print('%s:%s'%(temp,dict1[temp]))
else:
temp1 = input("请输入联系人电话:")
dict1[temp]=temp1
print('添加的联系人资料为:%s --> %s'%(temp,dict1[temp]))
continue
elif key ==2:
temp = input("请输入联系人的姓名:")
if temp in dict1:
print('您输入的姓名已在通讯录中存在 -->%s:%s'%(temp,dict1[temp]))
x = input("是否修改用户资(YES/NO)")
if x == 'YES':
tel = input("请输入用户联系电话:")
dict1.update({temp:tel})
print('修改后的联系人资料为 -->%s:%s'%(temp,dict1[temp]))
else:
continue
else:
temp1 = input("请输入联系人电话:")
dict1[temp]=temp1
print('添加的联系人资料为:%s --> %s'%(temp,dict1[temp]))
elif key ==3:
temp = input("请输入要删除的联系人姓名:")
if temp in dict1:
flag = input("确定要删除此联系人?(YES/NO)")
if flag == 'YES':
del(dict1[temp])
print('联系人 %s 删除成功!'%temp)
else:
continue
else:
print('%s 不在通讯录中!'%temp)
elif key ==4:
print("|--- 感谢使用通讯录程序 ---|")
break
==================== RESTART: /Users/wufq/Desktop/通讯录.py ====================
|--- 欢迎进入通讯录程序 ---|
|--- 1:查询联系人资料 ---|
|--- 2:插入新的联系人 ---|
|--- 3:删除已有联系人 ---|
|--- 4:退出通讯录程序 ---|
请输入相关的指令代码:1
请输入联系人的姓名:尘封
尘封:18088888888
请输入相关的指令代码:2
请输入联系人的姓名:尘封
您输入的姓名已在通讯录中存在 -->尘封:18088888888
是否修改用户资(YES/NO)YES
请输入用户联系电话:\15624963195
修改后的联系人资料为 -->尘封:15624963195
请输入相关的指令代码:3
请输入要删除的联系人姓名:尘封
确定要删除此联系人?(YES/NO)YES
联系人 尘封 删除成功!
请输入相关的指令代码:4
|--- 感谢使用通讯录程序 ---|
>>>
==================== RESTART: /Users/wufq/Desktop/通讯录.py ====================
【Python025-字典】的更多相关文章
- 【DG】Oracle_Data_Guard官方直译
[DG]Oracle Data Guard官方直译 1 Oracle Data Guard 介绍 Oracle Data Guard概念和管理10g版本2 Oracle Data Guard ...
- DVWA实验之Brute Force(暴力破解)- Low
DVWA实验之Brute Force-暴力破解- Low 这里开始DVWA的相关实验~ 有关DVWA环境搭建的教程请参考: https://www.cnblogs.com/0yst3r-2 ...
- Oracle错误览表
Oracle 错误总结及问题解决 ORA 本文转自:https://www.cnblogs.com/zhangwei595806165/p/4972016.html 作者@承影剑 ORA-0 ...
- 字典:当索引不好用时 - 零基础入门学习Python025
字典:当索引不好用时 让编程改变世界 Change the world by program 有天你想翻开牛津字典,查找"sadomasochism[ˌseɪdoʊ'mæsəkɪzəm]&q ...
- Javacript实现字典结构
字典是一种用[键,值]形式存储元素的数据结构.也称作映射,ECMAScript6中,原生用Map实现了字典结构. 下面代码是尝试用JS的Object对象来模拟实现一个字典结构. <script& ...
- python 数据类型 ----字典
字典由一对key:value 组成的 python中常用且重量级的数据类型 1. key , keys, values 字典由一对key:value 组成的 python中常用且重量级的数据类型 1. ...
- 增强版字典DictionaryEx
代码 public class DictionaryEx<TKey, TValue> : IDictionary<TKey, TValue> { /// <summary ...
- python学习笔记(字符串操作、字典操作、三级菜单实例)
字符串操作 name = "alex" print(name.capitalize()) #首字母大写 name = "my name is alex" pri ...
- python之最强王者(8)——字典(dictionary)
1.Python 字典(Dictionary) 字典是另一种可变容器模型,且可存储任意类型对象. 字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包 ...
- python序列,字典备忘
初识python备忘: 序列:列表,字符串,元组len(d),d[id],del d[id],data in d函数:cmp(x,y),len(seq),list(seq)根据字符串创建列表,max( ...
随机推荐
- python模拟艺龙网登录带验证码输入
1.使用urllib与urllib2包 2.使用cookielib自动管理cookie 3.360浏览器F12抓信息 登录请求地址和验证码地址都拿到了如图 # -*- coding: utf-8 -* ...
- php url链接地址传数组方法 json_decode解析数组失败 经过url链接的json数组解析出错的解决方法 (原)
先说出现的问题: 请求一个接口(例如 http://www.a.com/getmes.php)需要传一个数组参数 param ,值为 数组 array(0=>'刘师傅',1=>'1760 ...
- 前端forEach在Array、map、set中的使用,weakset,weakmap
数组: var s = ['a','b','c']; s.forEach(function(ele,index,array){ console.log(ele); }); Map: var map = ...
- Ajax三级联动
全国省市县查询 html代码 <!doctype html> <html> <head> <meta charset="utf-8"> ...
- featuremap尺寸的计算
对于卷积层,向下取整 对于池化层:想上取整 output=((input+2*pad-dilation*(kernel-1)+1)/stride)+1 input:输入尺寸 output:输出尺寸 p ...
- caffe的model参数解析numpy多维数组的存取
在caffe的参数进行Python解析时,需要对模型的wight和bias的参数进行解析,为了提高结果解析的可读性,需要用numpy将解析的文件进行保存 此时用到np.savetxt方法和np.sav ...
- Unity shader学习之逐顶点漫反射光照模型
公式如下: Cdiffuse = Clight * mdiffuse * max(0, dot(n,l)); 其中,n 为表面法线,l 为指向光源的单位向量,mdiffuse 为材质温反射颜色,Cdi ...
- report源码分析——宏的执行
uvm_info,uvm_error其实是对uvm_report_info,uvm_report_error的封装. 其中warning,error,fatal,macros默认都是定义为UVM_NO ...
- 2-1:math库与random库
一.math库: math库是python语言中常用的一个函数库,它包含了一批数学函数,下面我们看一下这个函数库 由于math库中的函数与数学中的函数比较一致,相对比较简单,请同学们自行练习一下: 二 ...
- 20155228 2016-2017-2 《Java程序设计》第3周学习总结
20155228 2016-2017-2 <Java程序设计>第3周学习总结 教材学习内容总结 认识对象 类与对象 类和对象的关系:类是对象的设计图,对象是类的实例 参考:将"名 ...