找回密码
 会员注册
查看: 33|回复: 0

Python八股文:基础知识Part1

[复制链接]

3

主题

0

回帖

10

积分

新手上路

积分
10
发表于 2024-9-6 19:59:33 | 显示全部楼层 |阅读模式
1.不用中间变量交换a和b这是python非常方便的一个功能可以这样直接交换两个值 2.可变数据类型字典在for循环中进行修改这道题在这里就是让我们去回答输出的内容,这里看似我们是在for循环中每一次加入了都在list中加入了一个字典,然后字典的键值对的value每次都加了1,实际上最后list中的值只会保留最后一个i的值,因为每一次我们对字典进行赋值的时候用的key都是同一个,每次修改都会将list中已有的字典都修改,内存中只有一个a这个字典的变量3.带有不同数据类型的交集并集差集这里我们一眼看上去可能会觉得这两个集合中的交集只有9.9和4+3j,但是我们忽略了在进行这种比较的时候,每个数据类型都有自己的Boolean形态,s1中的True,和s2中的1,在Booleanvalue中都代表True,所以也算是交集的一部分,同时我们可以发现在求交集的顺序的时候,其实是把后者作为优先,理解成在是s1&s2就是在s1中找s2里面的元素,所以第一个输出了1,第二个输出了True4.逻辑运算符的顺序在python中,我们进行逻辑运算的时候,参考的优先级应该是not->and->or,所以下面这个表达书中一开始我们就先把not3>2的结果算出来应该是False,然后我们再记录所有的and左右两边的表达式的结果(FalseandTrue)or(FalseandTrue)or(False),最后发现这三个括号中的and的结果都是False,所以最后or连接起来的最终结果还是False5.使用max()对字典默认比较的是字典中的key,而不是value,但是我们可以通过利用lambda匿名函数来修改keyparam的值来修改max函数的逻辑例如这里,key本身默认的是传入字典中key的值,但是这里我们修改为拿到key之后去找字典中key所对应的value的值,这样max()比较的就是每一个key的value大小了,并且返回的依然是key的值 6.自定义函数装饰器这里可以看到我们是如何定义装饰器的,或者可以给装饰器定义任意参数和关键字参数然后保证被修饰的函数可以传入任何参数defmy_decorator(func):defwrapper(*args,**kwargs):print("Somethingishappeningbeforethefunctioniscalled.")result=func(*args,**kwargs)print("Somethingishappeningafterthefunctioniscalled.")returnresultreturnwrapper#装饰器用法@my_decoratordefsay_hello(name):print("Hello,"+name+"!")return"Greetingsent."#调用被装饰的函数result=say_hello("Alice")print(result) 7.简单的复制文件代码8.Python的异常处理机制当面试官询问Python的异常处理机制时,你可以从以下几个方面来介绍:1.**异常的概念**:异常是Python中用于处理程序在运行过程中遇到的错误或异常情况的一种机制。当程序出现错误时,Python解释器会引发一个异常对象,导致程序执行被中断,同时异常对象包含了错误的相关信息。2.**异常处理语句**:在Python中,我们可以使用`try`、`except`、`else`和`finally`等关键字来处理异常。这些关键字可以使程序在出现异常时执行相应的处理逻辑,以保证程序的稳定性和可靠性。3.**`try-except`块**:`try-except`块用于捕获异常并进行处理。在`try`块中编写可能会引发异常的代码,然后在`except`块中指定处理异常的逻辑。如果`try`块中的代码引发了异常,则会跳转到相应的`except`块进行处理,而不会导致程序终止。4.**异常类型**:Python中有许多内置的异常类型,比如`SyntaxError`、`TypeError`、`ValueError`等。你可以根据具体的情况选择捕获特定类型的异常,以便进行精确的处理。5.**`else`块**:`else`块用于在`try`块中没有发生异常时执行的代码。如果`try`块中的代码成功执行完成,没有引发异常,则会执行`else`块中的代码。6.**`finally`块**:`finally`块用于在无论是否发生异常都需要执行的清理操作,比如关闭文件或释放资源。`finally`块中的代码会在`try`块中的代码执行完成后执行,即使`try`块中的代码引发了异常也会执行。try:#可能会引发异常的代码result=10/0exceptZeroDivisionError:#处理除零异常print("Errorivisionbyzero!")else:#如果没有异常发生时执行的代码print("Noexceptionsoccurred.")finally:#无论是否发生异常都需要执行的清理操作print("Cleaningupresources.")9.利用生成器计算一组数组的阶乘在Python中,生成器(Generator)是一种特殊的迭代器,它允许按需生成值,而不是一次性生成并存储所有值。生成器是使用函数和yield语句来创建的。当生成器函数被调用时,它会返回一个生成器对象,而不是执行函数体中的代码。每次调用生成器的next()方法或使用for循环迭代生成器时,生成器函数会从上一次停止的地方继续执行,直到遇到下一个yield语句,然后返回其值,并暂停执行。这使得生成器在处理大型数据集或无限序列时非常高效,因为它们在需要时逐个生成值,而不会一次性将所有值加载到内存中。 10.继承中的函数调用这里就是在说当我们调用一个子类中没有的函数的时候,就会去父类中找,然后呢在父类中调用f1函数用的是self,这里的self是实例化的对象,也就是说尽管调用的是父类的f1,但是obj是一个bar对象,所以self.f1()还是会callBar中的f1对象,而不是父类中的如果只有开头有双下划线__function而没有结尾,这通常是用于指示私有属性或方法。虽然Python中没有真正的私有属性或方法,但是以双下划线开头的属性或方法会被解释器修改名称,以避免与子类中的同名属性或方法冲突。 就像在这里,我们的私有方法是没办法在类外面进行访问的,所以当foo.f2被执行的时候,__f1()所指的就是我们Foo中的私有函数__f111.对象实例化的调用我们可以通过修改__call__这个内置函数来对一个实例化的对象进行调用12.单例模式单例模式是一种设计模式,它确保类只有一个实例,并提供一个全局访问点来访问该实例。单例模式通常用于管理共享资源、数据库连接、配置对象等。实现单例模式的方法通常包括:1.**懒汉式**:在需要时才创建单例实例。这种方法可能会导致线程安全问题,因此需要进行适当的同步处理。  classSingleton:    __instance=None      @classmethod    defget_instance(cls):      ifcls.__instanceisNone:        cls.__instance=Singleton()      returncls.__instance2.**饿汉式**:在类加载时就创建单例实例。这种方法在多线程环境下是线程安全的,但可能会浪费内存。  classSingleton:    __instance=Singleton()      @classmethod    defget_instance(cls):      returncls.__instance3.**基于装饰器**:使用装饰器来装饰类,使其只能有一个实例。  defsingleton(cls):    instances={}      defget_instance(*args,**kwargs):      ifclsnotininstances:        instances[cls]=cls(*args,**kwargs)      returninstances[cls]      returnget_instance    @singleton  classMyClass:    pass无论使用哪种方法,单例模式都可以确保在应用程序的生命周期中,只有一个实例被创建并且可以被全局访问。13.深拷贝和浅拷贝在python中我们列表本身的copy函数,list.copy()和copy包中的copy.copy()执行的都是浅拷贝,浅拷贝只成功”独立“拷贝了列表的外层,而列表的内层列表,还是共享的,这是因为,我们修改了嵌套的list,修改外层元素,会修改它的引用,让它们指向别的位置,修改嵌套列表中的元素,列表的地址并未发生变化,指向的都是用一个位置。在浅拷贝中,其实如果我们用id()来查看两个列表中每个元素单独的地址,你就会发现其实是一样的 深拷贝使得两个列表完全独立开来,每一个列表的操作,都不会影响到另一个 14.__new__和__init__的区别`__new__`和`__init__`都是Python中用于创建对象的特殊方法(也称为魔术方法或构造方法),它们在面向对象编程中起着不同的作用。__new__`方法:-`__new__`是一个静态方法(类方法),它在对象实际创建之前被调用。-`__new__`负责创建实例对象,并返回该实例对象。它是一个类级别的方法,因此它的第一个参数是类本身(通常命名为`cls`)。-`__new__`方法在对象实例化时最先被调用,它负责分配内存空间、创建对象,并返回对象的引用。-通常情况下,你不需要直接调用`__new__`方法,因为Python会在调用`__init__`方法之前自动调用`__new__`方法来创建对象。 __init__`方法:-`__init__`是一个实例方法,在对象创建后被调用,用于初始化对象的状态。-`__init__`方法可以接受额外的参数,用于初始化对象的属性。-`__init__`方法中通常包含初始化对象的代码,如给对象的属性赋值等。-当你使用类创建对象时,Python会在调用`__new__`方法创建对象后立即调用`__init__`方法来初始化对象。区别:-`__new__`是创建实例对象的方法,它负责分配内存空间并返回对象的引用,而`__init__`是初始化对象状态的方法,它负责给对象的属性赋初值。-`__new__`在对象实例化时调用,而`__init__`在对象初始化时调用。-`__new__`方法返回一个对象的引用,而`__init__`方法不返回任何值。总而言之,`__new__`和`__init__`在对象的创建和初始化过程中起着不同的作用,`__new__`负责创建对象,而`__init__`负责初始化对象的属性。通常情况下,你只需要在需要特殊处理时重写`__new__`方法,而`__init__`方法则用于初始化对象的常规属性。分配空间」是__new__方法,初始化是__init__方法15.map()函数返回的是一个迭代器iterator对象,需要用list()来转换成列表16.isinstance()和type()的区别type()不会认为子类是一种父类类型,不考虑继承关系isinstance()会认为子类是一种父类类型,考虑继承关系 17.Python常用的标准库os:提供不少于操作系统相关联的函数sys:提供了访问Python解释器相关信息的接口,比如命令行参数、标准输入输出等。通常用于命令行参数。datetime:日期时间re:正则匹配math:数学运算unitest:进行模块的单元测试random:提供生成伪随机数的函数threading:多线程编程相关功能time:提供了时间相关的函数和类,比如计时器json:提供对json数据的序列化反序列化操作socket:提供了网络编程相关的功能,比如创建TCP/UDP连接等。logging:提供了日志记录相关的功能。 18.装饰器的使用场景记录日志:装饰器可以用于记录函数的调用信息,包括输入参数和返回值。这对于调试和性能分析非常有用。deflog(func):defwrapper(*args,**kwargs):print(f"Callingfunction{func.__name__}")result=func(*args,**kwargs)print(f"Function{func.__name__}returned{result}")returnresultreturnwrapper@logdefadd(a,b):returna+badd(1,2)#输出:CallingfunctionaddFunctionaddreturned3计时:装饰器可以用于测量函数的执行时间。这对于性能优化和代码分析很有帮助。importtimedeftimer(func):defwrapper(*args,**kwargs):start_time=time.time()result=func(*args,**kwargs)end_time=time.time()print(f"Function{func.__name__}took{end_time-start_time}secondstorun")returnresultreturnwrapper@timerdeffibonacci(n):ifn
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 会员注册

本版积分规则

QQ|手机版|心飞设计-版权所有:微度网络信息技术服务中心 ( 鲁ICP备17032091号-12 )|网站地图

GMT+8, 2025-1-10 14:23 , Processed in 1.139245 second(s), 26 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表