免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3032 | 回复: 0
打印 上一主题 下一主题

Python 语法之字典 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-10-21 10:06 |只看该作者 |倒序浏览


  Normal
  0
  
  
  
  7.8 磅
  0
  2
  
  false
  false
  false
  
  EN-US
  ZH-CN
  X-NONE
  
   
   
   
   
   
   
   
   
   
   
   
   
   
   
   
   
   
   
  
  
   
   
   
   
   
   
   
   
   
   
   
  

  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  
  

/* Style Definitions */
table.MsoNormalTable
        {mso-style-name:普通表格;
        mso-tstyle-rowband-size:0;
        mso-tstyle-colband-size:0;
        mso-style-noshow:yes;
        mso-style-priority:99;
        mso-style-qformat:yes;
        mso-style-parent:"";
        mso-padding-alt:0cm 5.4pt 0cm 5.4pt;
        mso-para-margin:0cm;
        mso-para-margin-bottom:.0001pt;
        mso-pagination:widow-orphan;
        font-size:10.5pt;
        mso-bidi-font-size:11.0pt;
        font-family:"Calibri","sans-serif";
        mso-ascii-font-family:Calibri;
        mso-ascii-theme-font:minor-latin;
        mso-hansi-font-family:Calibri;
        mso-hansi-theme-font:minor-latin;
        mso-font-kerning:1.0pt;}
File information
2009-10-21
磁针石:xurongzhong#gmail.com
博客:
oychw.cublog.cn
参考资料:
《Python Essential Reference 4th
Edition 2009》
《beginning python from novice to
professional second edition 2008》


*特点:无序,是唯一内置的映射类型。多用于实现哈希表或者关联数组。
key具有唯一性,可以使用固定长度的对象,不能使用列表、字典和包含可变长度类型的元组。访问形式:m[k],k是key。如果找不到,报错:KeyError。
方法和操作如下:


  
  项目
  
  
  功能
  


  
  len(m)
  
  
   Key的长度
  


  
  m[k]
  
  
   
  


  
  m[k]=x
  
  
   
  


  
  del m[k]
  
  
   
  


  
  k in m
  
  
   有没有k的key
  


  
  m.clear()
  
  
   
  


  
  m.copy()
  
  
   
  


  
  m.fromkeys(s [,value])
  
  
   
  


  
  m.get(k [,v])
  
  
   
  


  
  m.has_key(k)
  
  
   
  


  
  m.items()
  
  
   
  


  
  m.keys()
  
  
   
  


  
  m.pop(k [,default])
  
  
   
  


  
  m.popitem()
  
  
   
  


  
  m.setdefault(k [, v])
  
  
   
  


  
  m.update(b)
  
  
   
  


  
  m.values()
  
  
   
  


*构建字典

字典举例:
phonebook = {'Alice': '2341', 'Beth':
'9102', 'Cecil': '3258'}
函数Dict可以从其他映射或者序列构建字典
>>> items = [('name', 'Gumby'),
('age', 42)]
>>> d = dict(items)
>>> d
{'age': 42, 'name': 'Gumby'}
>>> d['name']
'Gumby'

       也可以使用参数的方法:
>>> d = dict(name='Gumby', age=42)
>>> d
{'age': 42, 'name': 'Gumby'}
初始化空字典:
>>> x = {}
>>> x[42] = 'Foobar'
>>> x
{42: 'Foobar'}

*格式化输出:
>>> phonebook
{'Beth': '9102', 'Alice': '2341', 'Cecil':
'3258'}
>>> "Cecil's phone number is
%(Cecil)s." % phonebook
"Cecil's phone number is 3258."


>>>
template = '''
%(title)s
%(title)s
%(text)s
'''
>>>
data = {'title': 'My Home Page', 'text': 'Welcome to my home page!'}
>>>
print template % data
My
Home Page
My
Home Page
Welcome
to my home page!

另外string.Template 类也很适合这种应用。

*字典方法:
-*清除:clear
       下面例子展示clear和把字典置空字典的区别:
>>> x = {}
>>> y = x
>>> x['key'] = 'value'
>>> y
{'key': 'value'}
>>> x = {}
>>> y
{'key': 'value'}


>>> x = {}
>>> y = x
>>> x['key'] = 'value'
>>> y
{'key': 'value'}
>>> x.clear()
>>> y
{}


-*复制:copy

>>> x = {'username': 'admin',
'machines': ['foo', 'bar', 'baz']}
>>> y = x.copy()
>>> y['username'] = 'mlh'
>>> y['machines'].remove('bar')
>>> y
{'username': 'mlh', 'machines': ['foo',
'baz']}
>>> x
{'username': 'admin', 'machines': ['foo',
'baz']}

       浅拷贝的元素指向原有元素,所以改变原有的可变元素,新的也会受影响,反之亦然。换种说法,对元素进行替换,不会对新老都产生影响,但是修改则会有影响。

>>> from copy import deepcopy
>>> d = {}
>>> d['names'] = ['Alfred',
'Bertrand']
>>> c = d.copy()
>>> dc = deepcopy(d)
>>> d['names'].append('Clive')
>>> c
{'names': ['Alfred', 'Bertrand', 'Clive']}
>>> dc
{'names': ['Alfred', 'Bertrand']}

-*复制key:fromkeys
>>> {}.fromkeys(['name', 'age'])
{'age': None, 'name': None}
       也可以用dict代替{}
>>> dict.fromkeys(['name', 'age'])
{'age': None, 'name': None}
        设置其他默认值:
>>> dict.fromkeys(['name', 'age'],
'(unknown)')
{'age': '(unknown)', 'name': '(unknown)'}


-*获取:get

>>> d = {}
>>> print d['name']
Traceback (most recent call last):
File "", line 1, in
?
KeyError: 'name'
>>> print d.get('name')
None
也可以用其他字符替代None

>>> d.get('name', 'N/A')
'N/A'

-*has_key:是否有key
和k in d是等效的,Python 3.0将取消这个,建议不要使用
>>> d = {}
>>> d.has_key('name')
False
>>> d['name'] = 'Eric'
>>> d.has_key('name')
True

-*列出值:items and
iteritems
>>> d = {'title': 'Python Web
Site', 'url': 'http://www.python.org', 'spam': 0}
>>> d.items()
[('url', 'http://www.python.org'), ('spam',
0), ('title', 'Python Web Site')]

>>> it = d.iteritems()
>>> it
>>> list(it) # Convert the
iterator to a list
[('url', 'http://www.python.org'), ('spam',
0), ('title', 'Python Web Site')]
       Iteritems生成迭代器,一般的情况下使用iteritems比iteritem更有效,尤其是循环的时候。
注:Python 3 items 返回的是迭代器

-*列出关键字:keys
and iterkeys
       后者是迭代器
根据key出栈:pop
>>> d = {'x': 1, 'y': 2}
>>> d.pop('x')
1
>>> d
{'y': 2}
-*出栈:popitem
>>>
d
{'url':
'http://www.python.org', 'spam': 0, 'title': 'Python Web Site'}
>>>
d.popitem()
('url',
'http://www.python.org')
>>>
d
{'spam':
0, 'title': 'Python Web Site'}
       出栈和列表和类似,但是没有append。
-*setdefault:设置默认值。
>>>
d = {}
>>>
d.setdefault('name', 'N/A')
'N/A'
>>>
d
{'name':
'N/A'}
>>>
d['name'] = 'Gumby'
>>>
d.setdefault('name', 'N/A')
'Gumby'
>>>
d
{'name':
'Gumby'}
       默认值的默认值为None。
>>>
d = {}
>>>
print d.setdefault('name')
None
>>>
d
{'name':
None}

-*更新:update
>>> d = {
'title': 'Python Web Site',
'url': 'http://www.python.org',
'changed': 'Mar 14 22:09:15 MET 2008'
}
>>> x = {'title': 'Python Language
Website'}
>>> d.update(x)
>>> d
{'url': 'http://www.python.org', 'changed':
'Mar 14 22:09:15 MET 2008', 'title':
'Python Language Website'}


-*取值:values and
itervalues

>>> d = {}
>>> d[1] = 1
>>> d[2] = 2
>>> d[3] = 3
>>> d[4] = 1
>>> d.values()
[1, 2, 3, 1]


*实例:
存储个人的电话和地址的脚本:

# A simple
database

# A
dictionary with person names as keys. Each person is represented as
#
another dictionary with the keys 'phone' and 'addr' referring to their phone
# number
and address, respectively.

people =
{

    'Alice': {
        'phone': '2341',
        'addr': 'Foo drive 23'
    },

    'Beth': {
        'phone': '9102',
        'addr': 'Bar street 42'
    },

    'Cecil': {
        'phone': '3158',
        'addr': 'Baz avenue 90'
    }

}

#
Descriptive labels for the phone number and address. These will be used
# when
printing the output.
labels =
{
    'phone': 'phone number',
    'addr': 'address'
}

name =
raw_input('Name: ')

# Are we
looking for a phone number or an address?
request
= raw_input('Phone number (p) or address (a)? ')

# Use the
correct key:
if
request == 'p': key = 'phone'
if
request == 'a': key = 'addr'

# Only
try to print information if the name is a valid key in
# our
dictionary:
if name
in people: print "%s's %s is %s." % \
(name, labels[key], people[name][key])


将上述例子改为getkey

# A simple database

# A dictionary with person names as keys.
Each person is represented as
# another dictionary with the keys 'phone'
and 'addr' referring to their phone
# number and address, respectively.

people = {

   
'Alice': {
      
'phone': '2341',
      
'addr': 'Foo drive 23'
    },

   
'Beth': {
      
'phone': '9102',
      
'addr': 'Bar street 42'
    },

   
'Cecil': {
      
'phone': '3158',
      
'addr': 'Baz avenue 90'
    }

}


labels = {
   
'phone': 'phone number',
   
'addr': 'address'
}

name = raw_input('Name: ')

# Are we looking for a phone number or an
address?
request = raw_input('Phone number (p) or
address (a)? ')

# Use the correct key:
key = request # In case the request is
neither 'p' nor 'a'
if request == 'p': key = 'phone'
if request == 'a': key = 'addr'

# Use get to provide default values:
person = people.get(name, {})
label = labels.get(key, key)
result = person.get(key, 'not available')

print "%s's %s is %s." % (name,
label, result)


               
               
               

本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/21908/showart_2074565.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP