正则表达式学习
正则表达式学习
闭包是函数式编程的一个重要的语法结构,函数式编程是一种编程范式 (而面向过程编程和面向对象编程也都是编程范式)。
在面向过程编程中,我们见到过函数(function);
在面向对象编程中,我们见过对象(object);
函数和对象的根本目的是以某种逻辑方式组织代码,并提高代码的可重复使用性(reusability);
python面试相关
Python数据结构模块:
- collections
- functools
- heapq
- operator
- itertools
1 | del list[2] |
len([1,2,3])
,结果为3
[1,2,3]+[4,5,6]
,结果为[1,2,3,4,5,6]
['Hi']*4
,结果为['Hi'.'Hi','Hi','Hi']
3 in [1,2,3]
,结果为True
for x in [1,2,3]: print(x,end="")
,结果为1 2 3
1 | >>>squares = [1, 4, 9, 16, 25] |
元祖的元素不可修改。
元组使用小括号,列表使用方括号。
元组中的元素值是不允许修改的,但我们可以对元组进行连接组合,如下:
1 | tup1 = (12, 34.56); |
结果为:
1 | (12, 34.56, 'abc', 'xyz') |
py表达式 | 结果 | 描述 |
---|---|---|
len((1, 2, 3)) |
3 | 计算元素个数 |
(1, 2, 3) + (4, 5, 6) |
(1, 2, 3, 4, 5, 6) | 连接 |
('Hi!',) * 4 |
(‘Hi!’, ‘Hi!’, ‘Hi!’, ‘Hi!’) | 复制 |
3 in (1, 2, 3) |
True | 元素是否存在 |
for x in (1, 2, 3): print (x,) |
1 2 3 | 迭代 |
zip()
函数用于将可迭代的对象作为参数,将对象中对应的元素打包成一个个元组,然后返回由这些元组组成的对象,这样做的好处是节约了不少的内存。
可以使用list()转换来输出列表。
若各个迭代器的元素个数不一致,则返回列表长度与最短的对象相同,利用*
号操作符,可以将元祖解压为列表。
1 | a = [1,2,3] |
输出结果为:
1 | <class 'zip'> <class 'list'> |
1 | a = [ |
输出结果:
1 | <class 'zip'> <class 'list'> |
1 | a = [1,2,3] |
输出结果:
1 | <zip object at 0x7f3128d8d5c8> <class 'zip'> |
1 | a = [ |
输出结果:
1 | ([1, 2], [5, 6]) <class 'tuple'> |
1 | a = [[1,2,3],[3,4,5]] |
输出结果:
1 | [(1, 3), (2, 4), (3, 5)] |
在python中,strings,tuples和numbers是不可更改的对象,而list,dict是可以修改的对象。
python的参数传递:
python中一切都是对象,严格意义上不能说值传递还是引用传递,应该说传不可变对象和传可变对象。
python 传不可变对象实例
1 | def ChangeInt(a): |
传可变对象实例
可变镀锡在函数里修改了参数,那么在调用这个函数的函数里,原始的参数也被改变了。
1 | def changeme( mylist ): |
以下是调用函数时可使用的正式参数类型:
必需参数
必需参数须以正确的顺序传入函数,调用时的数量必须和声明时的一样。
调用printme()函数,你必须传入一个参数,不然会出现语法错误:
1 | #可写函数说明 |
关键字参数
关键字参数和函数调用关系紧密,函数调用使用关键字参数来确定传入的参数值。
使用关键字参数允许函数调用时参数的顺序与声明时不一致,因为Python解释器能够用参数名匹配参数值。
以下实例在函数printme()调用时使用参数名:
1 | def printme( str ): |
以下实例演示了函数参数的使用不需要使用指定顺序:
1 | #可写函数说明 |
默认参数
调用函数时,如果没有传递参数,则会使用默认参数。以下实例中如果没有传入age参数,则使用默认值:
1 | def printinfo( name, age = 35 ): |
不定长参数
Python中的函数可以处理比当初声明时更多的参数。这些参数叫做不定长参数,和上述2种参数不同,声明时不会命名。基本语法如下:
1 | def functionname([formal_args,] *var_args_tuple ): |
加上星号*
的参数会以元组(tuple)的形式导入,存放所有未命名的变量参数。
1 | # 可写函数说明 |
还有一种就是参数带两个星号**
基本语法如下:
1 | def functionname([formal_args,] **var_args_dict ): |
加了两个星号**
的参数会以字典的形式导入。
1 | # 可写函数说明 |
声明函数时,参数中星号*
可以单独出现,例如:
1 | def f(a,b,*,c): |
如果单独出现星号*
后的参数必须用关键字传入。
python使用lambda来创建匿名函数。
所谓匿名,是指不再使用def语句这样的标准形式定义一个函数。
语法
lambda函数的语法只包含一个语句,如下:
1 | lambda [arg1 [,arg2,.....argn]]:expression |
如下实例:
1 | # 可写函数说明 |
Python中,程序的变量并不是在哪个位置都可以访问的,访问权限决定于这个变量在哪里赋值的。
变量的作用域决定了在哪一部分程序可以访问哪个特定的变量名称。Python的作用域一共有4种,分别是:
以L -> E -> G -> B 的规则查找,即:在局部找不到,便会去局部外的局部找(例如闭包),再找不到就会去全局找,再者去内置中找。
1 | g_count = 0 # 全局作用域 |
内置作用域是通过一共名为builtin的标准模块来实现的,但是这个变量名自身并没有放入内置作用域内,所以必须导入这个文件才能够使用它。在Python3.0中,可以使用以下的代码来查看到底预定义了哪些变量:
1 | >>> import builtins |
Python中只有模块(module),类(class)以及函数(def、lambda)才会引入新的作用域,其它的代码块(如if/elif/else、try/except、for/while等)是不会引入新的作用域的,也就是说这些语句内定义的变量,外部也可以访问,如下代码:
1 | >>> if True: |
实例中msg变量定义在if语句块中,但外部还是可以访问的。
如果将msg定义在函数中,则它就是局部变量,外部不能访问。
全局变量和局部变量
定义在函数内部的变量拥有一个局部作用域,定义在函数外的拥有全局作用域。
局部变量只能在其被声明的函数内部访问,而全局变量可以在整个程序范围内访问。调用函数时,所有在函数内部声明的变量名称都将被加入到作用域中。如下实例:
1 | total = 0 # 这是一个全局变量 |
global和nonlocal关键字
当内部作用域想修改外部作用域的变量时,就要用到global和nonlocal关键字了。
以下实例修改全局变量num:
1 | #!/usr/bin/python3 |
如果要修改嵌套作用域(enclosing作用域,外层非全局作用域)中的变量则需要nonlocal关键字,如下实例:
1 | #!/usr/bin/python3 |