字典

1、字典的创建

字典是python中唯一的映射类型,字典的每一对键值key-value用冒号分开,每个对之间用逗号分开,用{}定义,如下所示:

dict={"key1":"value1","key2":"value2"}

字典对象是可变的,但key必须用不可变对象(可以用数字,字符串或元组,不能用列表)。
定义字典时,一般有2种方法:
一是直接定义,如:

dict={"blue":"123","red":"456"}

二是内建方法:fromkeys(创建一个新字典,以序列 seq 中元素做字典的键,val 为字典所有键对应的初始值(默认为None))

d={}.fromkeys(('name','passwd'),'123456')
#表示:{'name': '123456', 'passwd': '123456'}
2、访问字典的值

1)直接通过key访问

2)循环遍历访问

在python3中字典常用定义_数据类型

3、字典key-value的添加

可以通过dic[key] = value直接进行添加

在python3中字典常用定义_默认参数_02


我们会发现字典是无序的数据类型(指元素内部的存放数据与元素的放入顺序无关)

4、字典的删除
dic={'a':1,'b':2,'c':3,'d':4}

• dic.pop(key)

根据key值删除字典的元素;

• dic.popitem()

随机删除字典元素,返回(key,value)

• dic.clear()

删除字典中的所有元素

• del dic

删除字典本身

在python3中字典常用定义_元组_03

5、修改字典

修改时,可直接通过key值修改value,但不能修改key。

在python3中字典常用定义_元组_04


另外,在字典中,key是唯一的,所以在创建字典时,如果有重复的key,会替代已有的。(所以字典的fromkeys方法也可以用来去重)

6、字典的常用方法

1)dict.keys()——返回字典的所有key值

2)dict.values()——返回字典的所有values值

在python3中字典常用定义_数据类型_05


3)dict.get()——判断如果key存在于字典中,返回对应value值

4)dict.has_key()——判断字典中是否存在某个key值,返回True,False

在python3中字典常用定义_在python3中字典常用定义_06


5)dict.update()——用另一个字典来更新自己(不存在的添加,存在的更新)

在python3中字典常用定义_元组_07

7、总结

•字符串——’ ‘,” “,”“” “”“,”’ ”’
有序序列,不可变数据类型
•列表——[]
有序序列,可变数据类型
•元组——() ,(1,),(1,2)
有序序列,不可变数据类型
•集合——{1,2}(不能为空)
无序,可变数据类型
•字典——{},{“key”:”value”}
无序,可变数据类型

函数

定义一个函数

• 以 def 关键词开头,后接函数标识符名称和圆括号()和冒号 :(括号中的参数)
• 函数内容以冒号起始,并且缩进。
• 在缩进块中编写函数体,函数的返回值用 return 语句返回。一旦遇到return,函数就执行完毕,并将结果返回。没有遇到return时,返回值None。

def fun():
    return "hello"
    print "world"
print "hi"
print fun()

会返回hi、hello,不会返回world

•空函数
——定义一个什么事也不做的空函数,可以用 pass 语句,pass 用来作为占位符

def fun():
    pass
    return
函数调用与参数检查

Python 内置了很多有用的函数,如abs(),cmp()等我们可以直接调用。
但像abs()的作用是求绝对值,当传递给它的参数不是数字时,就会发生错误。这是数据类型的错误,它的检查可以用内置函数 isinstance 实现。
如:用isinstance判断参数是否是数值型的,再调用函数abs()求绝对值。

def myabs(aaa):
    if isinstance(aaa, (int,float,long)):
        print abs(aaa)   #调用函数
    else:
        print "请输入一个数字!!"
aaa = -2.2
myabs(aaa)

几种错误的提示信息:

数据类型不对——TypeError: bad operand type for abs(): ‘str’
参数个数不对——TypeError: myabs() takes exactly 1 argument (0 given)

函数返回值

函数可以返回多个值,实质上是返回一个元组tuple,
例,返回2个数的平均值和较大的那个数。

def fun(x,y):
    if not isinstance(x,int) or not isinstance(y,int):
        print 'Error Type'
    avg = sum((x, y)) / 2
    t = max(x, y)
    return (avg, t)

print fun(6,3)

结果:

在python3中字典常用定义_元组_08


返回时元组可以省略括号,即函数调用接收返回值时,按照位置赋值给变量。如:

myavg, myt = fun(6,3)
print myavg, myt
函数参数

在调用函数时可使用的参数类型有4种
这4种参数定义的顺序是:必选参数 > 默认参数 > 可变参数 > 关键字参数
•必选参数 ,默认参数
必选参数须以正确的顺序传入函数。调用时的数量必须和声明时的一样。
调用函数时,默认参数的值如果没有传入,则被认为是默认值。
而且必选参数在前,默认参数在后,如果默认参数在前,就会报错。
例:计算一个数的n次方,n默认为2

def pow(x, n=2):
    return x ** n
print pow(3)
print pow(3, 4)

结果为:

在python3中字典常用定义_数据类型_09


注意:默认参数必须是不可变数据类型

•可变参数
可变参数又叫位置参数,就是传入的参数个数是可变的,可以是 1 个、2 个到任意个,还可以是 0 个。
通常用args作为形参,接收的数据类型为元组。加了星号()的变量名会存放所有未命名的变量参数。
如果想将一个列表或者元组传入函数,也可通过*li ,将参数传入函数里。
例:传入一串数字,返回最大的和最小的

def fun(*args):
    print type(args)
    return max(args),min(args)
li = 1,23,6,58,9,11
print fun(*li)

结果:

在python3中字典常用定义_在python3中字典常用定义_10


•关键字参数

关键字参数和可变参数在用法上类似,它的形参是 **kwargs,kwargs接收的是字典。它使用关键字参数来确定传入的参数值。

使用关键字参数允许函数调用时参数的顺序与声明时不一致,因为 Python 解释器能够用参数名匹配参数值。

例:

def enroll(name,age=22,**kwargs):
    print "name:", name
    print "age:", age
    for k,w in kwargs.items():
        print '%s:%s' %(k,w)

enroll('blue',myclass='运维班',gender='女')

结果:

在python3中字典常用定义_默认参数_11

变量的作用域

变量分为2种,分别是:
• 局部变量:只能在函数内部使用的变量
• 全局变量:在整个程序中使用的变量
(可以用global强制将局部变量转换为全局变量,需要先转换,再赋值等

global  b
b=1

函数的高级特性

递归

递归简单来说就是对一个可以重复相同步骤的问题,反复的调用同一个函数进行解决问题。它有以下一些特点或要求:
1、在写递归函数时要有一个明确的结束条件;
2、在递归时,问题规模要越来越小;
3、递归函数效率不高,函数调用是通过栈的数据结构实现的,
4、每调用依次,栈就会多一层,最多999层,否则会出现栈溢出。

例如:求一个数(n)的阶乘,可以把它看成(n-1)*n,这样依次缩小问题

def fact(n):
    if n <= 0:
        print "error"
    elif n == 1:
        return 1
    else:
        return fact(n-1)*n
n = input()
print fact(n)

运行结果:

在python3中字典常用定义_元组_12

函数式编程

编程语言一般分为以下几类:
面向对象编程语言:java,c++, python
面向过程编程语言:c
面向函数编程语言(lisp,erlang)

列表生成式

列表生成式是Python 内置的非常简单却强大的可以用来创建 list的生成式
举一个简单的例子:
用 range(1, 8)可以生成1-7的列表,如果我们想要生成这些数的平方,我们第一个想到的就是循环。

li=range(1,8)
ll1=[]
print li
for i in li[:]:
    ll1.append(i*i)
print ll1

在这里,我们将学习使用列表生成式一步解决问题:

print [ i*i for i  in range(1,8)]

在python3中字典常用定义_元组_13


这样看起来比循环就简单了很多

列表生成式的书写格式:[i*i for i in range(1 , 8)]
第一:把要生成的元素 i*i 放到前面
第二:后面跟上for循环
这样就可以把list创建出来。
(for循环后面还可以加上if判断等语句,实现更复杂的功能)
如:

print [ i*i for i in range(0,20) if i %2 == 0]
筛选出偶数
print [ i+j for i in ‘123’ for j in ‘ABC’]
使用两层循环,生成全排列

在python3中字典常用定义_元组_14

小练习:
定义列表li = [‘HEllo’,’World’]
返回:[‘hello’,’world’]

li = ['HEllo', 'World', 1]
print [i.lower() for i in li if isinstance(i, str)]

先判断i是否是字符串,在将列表中的每一个字符串小写。

注意:
它只能用于可迭代数据类型,在我们学过的数据类型中,字符串、整型、列表、元组、集合、字典中,只有整型不是可迭代的。

生成器

• 定义:
在循环的过程中不断推算出后续的元素呢。
在 Python 中,这种一边循环一边计算的机制,称为生成器(Generator)
• 为什么需要生成器:
通过列表生成式,我们可以直接创建一个列表,受到内存限制,列表容量肯定是有限的。

生成器的创建方式:

1)把一个列表生成式的[ ] 改为 ( )

在python3中字典常用定义_元组_15


访问它的方法:

(1)循环(常用)

在python3中字典常用定义_数据类型_16


(2)g.next()

在python3中字典常用定义_元组_17

2)使用 yield的关键字,如果一个函数中又了yield的关键字,它就变成了一个generator了
例如:定义一函数fib,实现斐波那契数列(Fibonicci)
1 1 2 3 5 8 13 21…

def fib(max):
    n,a,b = 0,0,1
    while n < max:
        yield b
        a, b = b, a+b
        n += 1
for i in fib(4):
    print i

结果:

在python3中字典常用定义_默认参数_18


我们需要理解的是他的过程,当它遇到yield时,退出函数,执行外面的语句,执行完了之后,在回到退出的那一行继续执行后面。