Python字典创建、基本 *** 作以及常用方法

Python字典创建、基本 *** 作以及常用方法,第1张

创建一个空字典自需要一对大括号即可,从已有的键-值对映射或关键字参数创建字典需要使用 dict 函数(类)

把一个列表转为字典,列表的每一项都是长度为2的序列。

还可使用 关键字实参 (**kwargs)来调用这个函数,如下所示:

字典的基本 *** 作与序列十分相似:

字典与序列的不同:

方法 clear 删除所有的字典项(key-value)。

复制,得到原字典的一个新副本。

效果等同于调用 dict(d) 创建新字典。

copy() 执行的是 浅复制 ,若字典的值是一个可变对象,那么复制以后,相同一个键将关联到同一个对象,修改该对象,将同时修改两个字典。

模块copy中的函数deepcopy 可执行深复制。

方法fromkeys 创建一个新字典,其中包含指定的键,且每个键对应的值都是None,或者可以提供一个i额默认值。

方法get 为访问字典项提供了宽松的环境。通常,如果你试图访问字典中没有的项,将引发错误,而get直接返回None,或者可设置默认返回值。

当字典中不存在指定键时, setdefault(k,v) 添加一个指定键-值对;且返回指定键所关联的值。

这三个方法返回值属于一种名为 字典视图 的特殊类型。字典视图可用于迭代。另外,还可确定其长度以及对其执行成员资格检查。

这三个方法自大的特点是不可变,当你的接口试图对其他用户提供一个只读字典,而不希望他们修改的时候,这三个方法是很有用的;而且当原字典发生改变时,这些方法返回的对象也会跟着改变。

方法 pop 可用于获取与指定键相关联的值,并将该键-值对从字典中删除。

popitem随机删除一个键-值对,并返回一个二维的元组 (key, value) ,因为字典是无序的,所以其d出的顺序也是不确定的。

书上说,这个方法在大数据量时执行效率很高,但没有亲测。

方法update 使用一个字典中的项来更新另一个字典。

字段是Python是字典中唯一的键-值类型,是Python中非常重要的数据结构,因其用哈希的方式存储数据,其复杂度为O(1),速度非常快。下面列出字典的常用的用途.

一、字典中常见方法列表

代码如下:

#方法

#描述

-------------------------------------------------------------------------------------------------

D.clear()

#移除D中的所有项

D.copy()

#返回D的副本

D.fromkeys(seq[,val])

#返回从seq中获得的键和被设置为val的值的字典。可做类方法调用

D.get(key[,default])

#如果D[key]存在,将其返回否则返回给定的默认值None

D.has_key(key)

#检查D是否有给定键key

D.items()

#返回表示D项的(键,值)对列表

D.iteritems()

#从D.items()返回的(键,值)对中返回一个可迭代的对象

D.iterkeys()

#从D的键中返回一个可迭代对象

D.itervalues()

#从D的值中返回一个可迭代对象

D.keys()

#返回D键的列表

D.pop(key[,d])

#移除并且返回对应给定键key或给定的默认值D的值

D.popitem()

#从D中移除任意一项,并将其作为(键,值)对返回

D.setdefault(key[,default])

#如果D[key]存在则将其返回否则返回默认值None

D.update(other)

#将other中的每一项加入到D中。

D.values()

#返回D中值的列表

二、创建字典的五种方法

方法一:

常规方法

代码如下:

#

如果事先能拼出整个字典,则此方法比较方便

>>>

D1

=

{'name':'Bob','age':40}

方法二:

动态创建

代码如下:

#

如果需要动态地建立字典的一个字段,则此方法比较方便

>>>

D2

=

{}

>>>

D2['name']

=

'Bob'

>>>

D2['age']

=

40

>>>

D2

{'age':

40,

'name':

'Bob'}

方法三:

dict--关键字形式

代码如下:

#

代码比较少,但键必须为字符串型。常用于函数赋值

>>>

D3

=

dict(name='Bob',age=45)

>>>

D3

{'age':

45,

'name':

'Bob'}

方法四:

dict--键值序列

代码如下:

#

如果需要将键值逐步建成序列,则此方式比较有用,常与zip函数一起使用

>>>

D4

=

dict([('name','Bob'),('age',40)])

>>>

D4

{'age':

40,

'name':

'Bob'}

代码如下:

>>>

D

=

dict(zip(('name','bob'),('age',40)))

>>>

D

{'bob':

40,

'name':

'age'}

方法五:

dict--fromkeys方法#

如果键的值都相同的话,用这种方式比较好,并可以用fromkeys来初始化

代码如下:

>>>

D5

=

dict.fromkeys(['A','B'],0)

>>>

D5

{'A':

0,

'B':

0}

如果键的值没提供的话,默认为None

代码如下:

>>>

D3

=

dict.fromkeys(['A','B'])

>>>

D3

{'A':

None,

'B':

None}

三、字典中键值遍历方法

代码如下:

>>>

D

=

{'x':1,

'y':2,

'z':3}

#

方法一

>>>

for

key

in

D:

print

key,

'=>',

D[key]

y

=>

2

x

=>

1

z

=>

3

>>>

for

key,

value

in

D.items():

#

方法二

print

key,

'=>',

value

y

=>

2

x

=>

1

z

=>

3

>>>

for

key

in

D.iterkeys():

#

方法三

print

key,

'=>',

D[key]

y

=>

2

x

=>

1

z

=>

3

>>>

for

value

in

D.values():

#

方法四

print

value

2

1

3

>>>

for

key,

value

in

D.iteritems():

#

方法五

print

key,

'=>',

value

y

=>

2

x

=>

1

z

=>

3

Note:用D.iteritems(),

D.iterkeys()的方法要比没有iter的快的多。

四、字典的常用用途之一代替switch

在C/C++/Java语言中,有个很方便的函数switch,比如:

代码如下:

public

class

test

{

public

static

void

main(String[]

args)

{

String

s

=

"C"

switch

(s){

case

"A":

System.out.println("A")

break

case

"B":

System.out.println("B")

break

case

"C":

System.out.println("C")

break

default:

System.out.println("D")

}

}

}

在Python中要实现同样的功能,

方法一,就是用if,

else语句来实现,比如:

代码如下:

from

__future__

import

division

def

add(x,

y):

return

x

+

y

def

sub(x,

y):

return

x

-

y

def

mul(x,

y):

return

x

*

y

def

div(x,

y):

return

x

/

y

def

operator(x,

y,

sep='+'):

if

sep

==

'+':

print

add(x,

y)

elif

sep

==

'-':

print

sub(x,

y)

elif

sep

==

'*':

print

mul(x,

y)

elif

sep

==

'/':

print

div(x,

y)

else:

print

'Something

Wrong'

print

__name__

if

__name__

==

'__main__':

x

=

int(raw_input("Enter

the

1st

number:

"))

y

=

int(raw_input("Enter

the

2nd

number:

"))

s

=

raw_input("Enter

operation

here(+

-

*

/):

")

operator(x,

y,

s)

方法二,用字典来巧妙实现同样的switch的功能,比如:

代码如下:

#coding=gbk

from

__future__

import

division

x

=

int(raw_input("Enter

the

1st

number:

"))

y

=

int(raw_input("Enter

the

2nd

number:

"))

def

operator(o):

dict_oper

=

{

'+':

lambda

x,

y:

x

+

y,

'-':

lambda

x,

y:

x

-

y,

'*':

lambda

x,

y:

x

*

y,

'/':

lambda

x,

y:

x

/

y}

return

dict_oper.get(o)(x,

y)

if

__name__

==

'__main__':

o

=

raw_input("Enter

operation

here(+

-

*

/):

")

print

operator(o)

1.传统的文字表达式:

>>> d={'name':'Allen','age':21,'gender':'male'}

>>> d

{'age': 21, 'name': 'Allen', 'gender': 'male'}

如果你可以事先拼出整个字典,这种方式是很方便的。

2.动态分配键值:

>>> d={}

>>> d['name']='Allen'

>>> d['age']=21

>>> d['gender']='male'

>>> d

{'age': 21, 'name': 'Allen', 'gender': 'male'}

如果你需要一次动态地建立一个字典的一个字段,那么这种方式比较合适。

字典与列表不同,不能通过偏移量进行复制,只能通过键来读取或赋值,所以也可以这样为字典赋值,当然访问不存在的键会报错:

>>> d[1]='abcd'

>>> d

{1: 'abcd', 'age': 21, 'name': 'Allen', 'gender': 'male'}

>>> d[2]

Traceback (most recent call last):

  File "<pyshell#9>", line 1, in <module>d[2]

  KeyError: 212345678

3.字典键值表

>>> c = dict(name='Allen', age=14, gender='male')

>>> c

{'gender': 'male', 'name': 'Allen', 'age': 14}

因为这种形式语法简单,不易出错,所以非常流行。

这种形式所需的代码比常量少,但是键必须都是字符串才行,所以下列代码会报错:

>>> c = dict(name='Allen', age=14, gender='male', 1='abcd')

SyntaxError: keyword can't be an expression

4.字典键值元组表

>>> e=dict([('name','Allen'),('age',21),('gender','male')])

>>> e

{'age': 21, 'name': 'Allen', 'gender': 'male'}

如果你需要在程序运行时把键和值逐步建成序列,那么这种方式比较有用。

5.所有键的值都相同或者赋予初始值:

>>> f=dict.fromkeys(['height','weight'],'normal')

>>> f

{'weight': 'normal', 'height': 'normal'}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11807998.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-18
下一篇 2023-05-18

发表评论

登录后才能评论

评论列表(0条)

保存