python-26-字典:当索引不好用时

1、字典是Python中唯一的映射类型 

2、字典包含两个要素:键(key)和值(value)他们是成对出现的,用大括号括起来,多对存在时用逗号隔开。 
3、可以用dict()直接创建字典,如dict1 = dict(((‘F’,70),(‘i’,105),(’s’,115),(‘h’,104),(‘C’,67))),创建出来的字典dict1的形式为{(‘F’,70),(‘i’,105),(’s’,115),(‘h’,104),(‘C’,67)} 
4、dict2 = dict(key1 = value1,key2 = value2),则最后的形式为:dict2 = {key2:value2,key1:value1}Python的dict是无序的。 
5、改变字典中的某个值:dict2[key] = ‘value’,插入的方法类似

>>> ditc1

{'鱼c工作室': '让编程改变世界', '李宁': '一切皆有可能', '阿迪达斯': 'impossible is nothing', '耐克': 'just do it'}

>>> print('鱼c工作室的口号是:',ditc1['鱼c工作室'])

鱼c工作室的口号是: 让编程改变世界

 >>> dict2={1:'one',2:'two',3:'three'}
>>> dict2[2]
'two'
>>> dict3=[]
>>> dict3
[]

>>> help(dict)

>>> dict3=dict((('f',70),('i',105),('h',104),('c',67)))
>>> dict3

{'f': 70, 'i': 105, 'h': 104, 'c': 67}

这里dict只有一个参数,所以用元组的方式代表只有一个元素

>>> dict4=dict(小甲鱼='让编程改变世界',苍井空='让av政府所有宅男')
>>> dict4

{'苍井空': '让av政府所有宅男', '小甲鱼': '让编程改变世界'}

>>> dict4['苍井空']
'让av政府所有宅男'
>>> dict4['苍井空']='所有av从业者都要通过学习辅导来'
>>> dict4['苍井空']

'所有av从业者都要通过学习辅导来'

>>> dict4['爱迪生']='天才是百分之一的灵感加百分之九十九的汗水'
>>> dict4

{'苍井空': '所有av从业者都要通过学习辅导来', '小甲鱼': '让编程改变世界', '爱迪生': '天才是百分之一的灵感加百分之九十九的汗水'}

典型课后题 
当你听到小伙伴们在谈论“映射”、“哈希”、“散列”或者“关系数组”的时候,事实上他们就是在讨论什么呢?

答:是的,事实上他们就是在讨论我们这一讲介绍的“字典”,都是一个概念!

尝试一下将数据(’F’: 70, ‘C’: 67, ‘h’: 104, ‘i’: 105, ‘s’: 115)创建为一个字典并访问键 ‘C’ 对应的值?

>>> dict1 = {'F' : 70 , 'C' : 67 , 'h' : 104 , 'i' : 105 , 's' : 115}
>>> dict2 = dict((('F' , 70),('C' , 67),('h' , 104),('i' , 105),('s' , 115)))
>>> dict1
{'F': 70, 'C': 67, 'h': 104, 'i': 105, 's': 115}
>>> dict2
{'F': 70, 'C': 67, 'h': 104, 'i': 105, 's': 115}
>>> dict1['C']
67
>>> dict2['C']
67
>>> 

用方括号(“[]”)括起来的数据我们叫列表,那么使用大括号(“{}”)括起来的数据我们就叫字典,对吗?

答:不对 
论坛参考答案:

    >>> NotADict = {1,2,3,4,5}  
    >>> type(NotADict)  
    <class 'set'>  
  • 1
  • 2
  • 3

不难发现,虽然我们用大括号(“{}”)把一些数据括起来了,但由于没有反映出这些数据有映射的关系,所以创建出 
来的不是字典,而是叫’set’的东西,那’set’到底又是啥玩意儿呢?请看第027讲 | 集合:在我的世界里,你就是唯 

一!

你如何理解有些东西字典做得到,但“万能的”列表却难以实现(臣妾做不到T_T)?

论坛参考答案:

举个例子:

    >>> brand = ['李宁','耐克','阿迪达斯','鱼C工作室']  
    >>> slogan = ['一切皆有可能','Just do it','Impossible is nothing','让编程改变世界']  
    >>> print('鱼C工作室的口号是:',slogan[brand.index('鱼C工作室')])  
    鱼C工作室的口号是: 让编程改变世界  
  • 1
  • 2
  • 3
  • 4

列表brand、slogan的索引和相对的值是没有任何关系的,我们可以看出唯一有联系的就是两个列表间,索引号相同的 
元素是有关系的(品牌对应口号嘛),所以这里我们通过brand.index(‘鱼C工作室’)这样的语句,间接的实现通过品牌 
查找对应的口号的功能。

这确实是一种可实现方法,呃……但用起来呢,多少有些别扭,效率还不高咧。况且Python是以简洁为主,这样子的实 
现肯定是不能让人满意的,所以呢,我们需要有字典这种映射类型的出现:

>>> dict1 = {'李宁':'一切皆有可能','耐克':'Just do it','阿迪达斯':'Impossible is nothing','鱼C工作室':'让编程改变世界'}  
>>> print('鱼C工作室的口号是:',dict1['鱼C工作室'])  
鱼C工作室的口号是: 让编程改变世界 

下边这些代码,他们都在执行一样的操作吗?你看得出差别吗?

    >>> 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)])  
    >>> d = dict({'three':3,'one':1,'two':2})  
  • 1
  • 2
  • 3
  • 4
  • 5

答:是的,他们都在创建字典:a = dict(one=1, two=2, three=3),呃,我是看不出差别啦~

实际运行效果为:

    >>> a  
    {'two': 2, 'three': 3, 'one': 1}  
    >>> b  
    {'two': 2, 'three': 3, 'one': 1}  
    >>> c  
    {'two': 2, 'three': 3, 'one': 1}  
    >>> d  
    {'two': 2, 'three': 3, 'one': 1}  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

说明Python的dict()是无序的,即dict的遍历顺序与初始化顺序是不一致的。可以参考:http://book.douban.com/annotation/23775810/ 
Python的Dict的用法:http://blog.csdn.net/wangran51/article/details/8440848

如图,你可以推测出打了马赛克部分的代码吗? 

data.split(',')

  data.split(',')  

这里split的用法做一个简单介绍:

js切割字符串主要分为三种,一种是较为常见的通过单一字符将一个字符串切割成多字符串,另一种是通过多个字符将一个字符串切割成多字符串,最后一种是通过一个短字符串将一个场子付出切割成多字符串。

1.通过单一字符将字符串切割成多字符

var data= "外面在下雨,天气真冷,你现在到哪里了呀,我们待会一起吃饭吧。";
var str = data.split(',');
结果:
str[0] =外面在下雨
str[1] =天气真冷
str[2] =你现在到哪里了呀
str[3] =我们待会一起吃饭吧。

2.通过多字符将字符串切割成多字符串
var data= "外面在下雨,天气真冷,你现在到哪里了呀,我们待会一起吃饭吧。";
var str = data.split(/在,/);
结果:
str[0] =外面
str[1] =下雨
str[2] =天气真冷
str[3] =你现
str[4] =到哪里了呀
str[5] =我们待会一起吃饭吧。

3.通过字符串将字符串切割成多字符串
var data = "abbcaaflajbbcafdfbbcioerfad";
var str = data.split('bbc');
结果:
str[0] =a
str[1] =aaflaj
str[2] = afdf
str[3] = ioerfad


本程序:

data="1000,小甲鱼,男"

MyDict={}
(MyDict['id'],MyDict['name'],MyDict['sex'])=data.split(',')
print("ID:"+MyDict['id'])
print("Name:"+MyDict['name'])

print("Sex:"+MyDict['sex'])


print('|---欢迎进入通讯录程序---|')
print('|---1:查询联系人资料  ---|')
print('|---2:插入新的联系人  ---|')
print('|---3:删除已有联系人  ---|')
print('|---4:退出通讯录程序  ---|')
num=5
data={'小甲鱼':'020-88974651'}
while num!=4:
    num=int(input('请输入相关的指令代码:'))
    if num==1:
        name=input('请输入联系人姓名:')
        print('%s:%s'%(name,data[name]))
        continue
    elif num==2:
        name=input('请输入联系人姓名:')
       
        if name in data:
            print('您输入的姓名在通讯录中已存在-->%s:%s'%(name,data[name]))
        
            n=input('您是否修改用户资料(YES/NO):')
            if n=='yes':
                number=input('请输入用户联系电话:')
                data.update({name:number})
                print('%s:%s'%(name,data[name]))
    
        else:
            number=input('请输入联系人电话:')
            data[name]=number
            print('%s:%s'%(name,data[name]))
                
    elif num==3:
        name=input('请输入您要删除的联系人:')
        n=input('您确定要删除么?(YES/NO):')
        if n=='yes':
            del(data[name])
            print('联系人%s删除成功!'%name)
        else:
            continue
    elif num==4:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值