python必刷面试_Python面试必刷题系列(5)

本篇是【Python面试必刷题系列】的第5篇文章。通过收集、整理Python真实面试题,给大家讲解面试中的python高频考察点,希望能够引起读者的足够重视。

往期回顾:

Python中 is 和 == 有什么区别?

(1)==是比较运算符,用来比较两个对象的value(值)是否相等。

(2)is也叫做同一性运算符,用来比较对象间的唯一身份标识(id)是否一致。

请看示例:

a = b = "abc"X = "abc"print a == b  # Trueprint a == X  # Trueprint a is b  # Trueprint a is X  # Truea = b = [1, 2, 3]X = [1, 2, 3]print a == b  # Trueprint a == X  # Trueprint a is b  # Trueprint a is X  # False

结论:只有数值型和字符串型比较,a is X才为True,当是tuple,list,dict或set型时,a is X为False。

原因:id(a) != id(X),感兴趣的同学可以试一下。

列举sort 和 sorted 的区别

sort 只是应用在 list 上的方法,就地排序,无返回值。

sorted 是内建函数,对所有可迭代的对象都可进行排序,返回新的list。

sorted 语法:

sorted(iterable, key=None, reverse=False)

参数说明:

iterable -- 可迭代对象。

key -- 主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素来进行排序。

reverse -- 排序规则,reverse = True 降序 , reverse = False 升序(默认)。

什么是猴子补丁?

在运行期间动态修改一个类或模块,叫做猴子补丁(Monkey Patch)。

用法一:运行时动态替换模块的方法

class Person(object):    def speak(self):        print "oooooo"def speak_patch(self):    print "eeeeee"if __name__ == '__main__':    Person.speak = speak_patch    person = Person()    person.speak() # 输出是 “eeeee”,相当于临时替换了模块里的方法

用法二:运行时动态增加模块的方法

这种场景也比较多,比如我们引用团队通用库里的一个模块,又想丰富模块的功能,除了继承之外也可以考虑用Monkey Patch。

成员变量用单、双下划线修饰的区别?

(1)

_xxx : 保护型成员变量,只允许该类及其子类访问;不能用于from module import * 。

(2)

__xxx : 私有型成员变量,只允许该类本身进行访问,连子类也不允许。

(3)

__xxx__ : python内置的专用特殊方法。像__init__()之类

的。

说说lambda表达式的应用场景?

lambda 表达式的本质就是匿名的、函数体仅有一行的函数。

# lambda表达式lambda x , y : x + y# 改写成函数def add(x, y):    return x+ y

虽然函数比 lambda 表达式的适应性更强,能够创建复杂的函数对象,但 lambda 表达式依然有如下两个优点:

对于单行函数,使用 lambda 表达式可以省去定义函数的过程,让代码更加简洁。

对于不需要多次复用的函数,使用 lambda 表达式可以在用完之后立即释放,提高了性能。

例子如下:

a = [('a', 1), ('b', 2), ('c', 3), ('d', 4)]a_1 = list(map(lambda x: x[0], a))

copy 和 deepcopy 的区别是什么?

结论:

浅拷贝,只拷贝父对象,不会拷贝父对象内部的子对象。

深拷贝,既拷贝父对象,又拷贝各级子对象。

理解:

import copyorigin = [1, 2, [3, 4]]  # origin 里边有三个元素:1, 2,[3, 4]cop1 = copy.copy(origin)cop2 = copy.deepcopy(origin)print cop1 == cop2  # Trueprint cop1 is cop2  # False# 说明: cop1 和 cop2 目前看上去还相同,但已不再是同一个objectorigin[2][0] = "hey!"origin[0] = "a"print origin  # ['a', 2, ['hey!', 4]]print cop1  # [1, 2, ['hey!', 4]]print cop2  # [1, 2, [3, 4]]# 说明: origin第一层元素改变,对深浅拷贝都不会有影响;# 但是子对象(origin[2] = [3, 4])发生改变后,浅拷贝会跟着变,深拷贝却不受影响

也就是说,如果父元素的第一层中存在可变对象,如list、dict以及普通类的实例对象等,使用浅拷贝只是传递了可变对象的引用,而深拷贝才是通俗理解上的完全复制。

下面是在普通类实例上做的一组测试,感兴趣的同学可以继续看,结论与上面一致。

import copyclass OBJ(object):    X = [1, 2, [1, 2]]  # 类变量    def __init__(self):        self.x = [1, 2, [1, 2]]  # 实例变量# 深浅拷贝origin = OBJ()cop1 = copy.copy(origin)cop2 = copy.deepcopy(origin)# 改变实例对象的属性origin.x[0] = "**"origin.x[2][1] = "##"print cop1.x  # ['**', 2, [1, '##']]print cop2.x  # [1, 2, [1, 2]]# 改变类变量的属性origin.X[0] = "**"origin.X[2][1] = "##"print cop1.X  # ['**', 2, [1, '##']]print cop2.X  # ['**', 2, [1, '##']]

什么是断言?应用场景?

python的assert是用来检查一个条件,如果它为真,继续往下执行。如果它为假,则会抛出AssertError 错误信息,并终止执行程序。

例如:

x = 23assert x > 0, "x is not positive"assert x%2 == 0, "x is not an even number"

结果显示:

Traceback (most recent call last):  File "/Users/arrnos/PycharmProjects/wechat/interface.py", line 3, in     assert x%2 == 0, "x is not an even number"AssertionError: x is not an even number

断言是保证程序运行可靠性的一种方式,因为,在条件不符合我们预期时,程序会自动在断言处终止运行,同时会抛出错误所在的代码行和相关信息,也算是一种程序问题定位的手段。

具体应用场景:函数入参检查、运行时程序逻辑检查、约定检查、程序常量以及文档检查等。

详细可参考:https://www.cnblogs.com/zhuifeng-mayi/p/9248558.html

dir()是做什么的?

dir()是python的一种内置函数,dir(object)用于查看object内部的全部属性和方法。

比如查看list、字符串或者是os模块的全部内部函数和方法,可以这样:

print dir(os)print dir(list)print dir("")print dir(str) # 和上面运行结果一致

*args和 * *kwargs 的含义及用法。

在函数定义中使用 *args 和**kwargs传递可变长参数。 *args用来将参数打包成 tuple 给函数体调用。** kwargs用于将关键字参数打包成 dict 给函数体调用。

(1) *和**的用法:拆包

def fun1(a, b):    print a, bdef fun2(b, a):    print a, bfun1(*[1, 2]) # *用于拆解list或元组,拆解结果作为位置参数fun2(**{"a": 1, "b": 3}) # **用于拆解字典,并将其作为关键字参数

结果:

1 21 3

(2) *args 用法实例:

*args用于接收元组作为位置参数。

def fun(a, *args):    print a    print "args:", args    print "type(args):", type(args)    for arg in args:        print arg# 调用fun(1, 2, 3)

结果:

1args: (2, 3)type(args): 23

(3)**kwargs用于接收字典类型的参数

def fun(a, **kwargs):    print "a is ", a    print "kwargs:", kwargs    print "type(kwargs):", type(kwargs)    print "b is ", kwargs.get("b", None)    print "c is ", kwargs.get("c", None)    print "d is ", kwargs.get("d", None)# 调用fun(1, b=3, c=5)

结果:

a is  1kwargs: {'c': 5, 'b': 3}type(kwargs): b is  3c is  5d is  None

type、class和object之间的关系?

(1) type : 用来返回一个对象的类型

f4a5699866dc9d6e5bc06159c12cce84.png

(2) object

由于Python中一切皆对象,也就是说Python中的任何变量类型都是可以被修改的,这也是Python等动态编程语言的特点。type的基类是object,但是object也是由type生成的,他们之间形成了一个环路,这样设计的目的也就是为了方便对这些数据结构进行修改。

(3) class

class是用来描述一个类对象的,通过class可以实例化出一个对象。

(4) type,class,object三者之间的关系:

6882f9be93d0b3552e80b870b2edd00f.png

比心

ddec055057b13d8ecca93ef75a45d494.png

推荐阅读:

【算法研习社】

机器学习、数据挖掘、推荐系统、架构编程

7073eaf4e2ce189cfc31b3ef95ceb062.png

海量干货,持续发送

大厂内推、技术资料获取,加小编微信,拉你进

【算法研习社 - 交流群】

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值