资讯详情

python面试题搜集

1. Python面试题搜集(一)

2019 Python吐血总结最新面试题及答案16道题!Python面试题集锦(附答案)

Python是目前编程领域最流行的语言。本文将总结Python面试中最常见的50个问题。每个问题都提供了参考答案,希望能帮助你在2019年的求职面试中脱颖而出,找到一份高薪的工作。这些面试问题涉及到Python基础知识、Python编程、数据分析和Python函数库等方面。

img

Python它是一种解释性语言。不同于C语言,Python操作前无需编译。

Python当你声明变量或类似变量时,你不需要声明变量的类型。

Python由于允许类别的定义、组合和继承,适合面向对象的编程。Python没有访问说明(如C 的public,private)。

在Python函数是第一类对象。它们可以分配给变量。类也是第一类对象

编写Python代码快,但运行慢。Python允许基于C的扩展,例如numpy函数库。

Python可用于许多领域。Web应用程序开发、自动化、数学建模、大数据应用程序等。它也经常被用作胶水代码。

Python可以编写脚本,但一般来说,它被认为是一种通用的编程语言。

Python操作前无需解释程序。Python是一种解释性语言。

PEP代表Python Enhancement Proposal。它是一组规则,指定如何格式化Python获得最大可读性的代码。

python内存管理原因Python所有私人堆空间管理。Python对象和数据结构都位于私有堆中。程序员无权访问此私有堆。python解释器负责处理这个问题。

Python对象堆空间分配的原因Python完成内存管理器。API为程序员提供一些编写代码的工具。

Python还有一个内置的垃圾收集器,可以回收所有未使用的内存,并将其用于堆放空间。

命名空间是一个命名系统,用于确保名称是唯一的,以避免命名冲突。

它是导入模块时使用的环境变量。每当导入模块时,也会发现PYTHONPATH检查每个目录中是否有导入模块。解释器使用它来确定要加载的模块。

Python模块是包含Python代码的.py该代码可以是函数类或变量。一些常用的内置模块包括:sys、math、random、data time、JSON。

全局变量:函数外或全局空间中声明的变量称为全局变量。程序中的任何函数都可以访问这些变量。

局部变量:函数中声明的任何变量都称为局部变量。这种变量存在于局部空间,而不是全局空间。

是。Python是区分大小写的语言。

类型转换是指将一种数据类型转换为另一种数据类型。

int() ?- 将任何数据类型转换为整数类型

float() ?- 将任何数据类型转换为float类型

ord() ?- 将字符转换为整数

hex() – 将整数转换为16制

oct() ?- 将整数转换为八进制

tuple() -?该函数用于转换为元组。

set() -?该函数正在转换为set返回类型。

list() -?该函数用于将任何数据类型转换为列表类型。

dict() -?该函数用于将顺序元组(键、值)转换为字典。

str() -?将整数转换为字符串。

complex(real,imag)? – 该函数将实数转换为复数(实数、图像)数。

要在Windows上安装Python,按以下步骤操作:

安装以下链接python:https://http://www.python.org/downloads/

下载后,将其安装在您身上PC在命令提示符下使用以下命令进行搜索PC上安装PYTHON的位置:cmd python。

然后转到高级系统设置并添加新的变量变量PYTHON_NAME并粘贴复制路径。

查找路径变量,选择其值并选择编辑。

如果值不存在,请在值的末尾添加分号,然后键入%PYTHON_HOME%

缩进是Python必要的。它指定了一个代码块。循环、类、函数中的所有代码都指定在缩进块中。通常使用四个空格字符。如果不需要缩进您的代码,它将无法准确执行并抛出错误。

Python数组和列表有相同的数据存储方式。但是,数组只能包含单个数据类型元素,而列表可以包含任何数据类型元素。

函数是代码块,只有在被调用时才能执行。Python需要使用中定义函数def关键字。

__init__是Python方法或结构。创建新对象/实例时,自动调用此方法分配内存。所有类别都有__init__方法。

lambda函数也被称为匿名函数,它可以包含任何数量的参数,但只个执行语句。

self是类的实例或对象。Python中,self包含在第一个参数中。Java情况并非如此,它是可选的。它有助于区分具有局部变量的方法和属性。init方法中的self变量引用新创建的对象,而其他方法则引用其方法调用的对象。

[:: – 1]逆转数组或序列的顺序。

可以使用shuffle随机列表函数元素。

代码输出为:

迭代器是可以遍历或迭代的对象。

random模块是用于生成随机数的标准模块。该方法定义为:

作者:前锋教育

链接:https://zhuanlan.zhihu.com/p/71913026

来源:知乎

作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

random.random()方法返回[0,1]范围内的浮点数。该函数产生随机浮点数。随机使用的方法是隐藏实例的绑定方法。可以使用Random例子显示创建不同线程实例的多线程序。其他随机生成器是:

randrange(a,b):它选择一个整数并定义它[a,b]之间的范围。它通过从指定范围中随机选择元素来返回元素。它不构建范围对象。

uniform(a,b):它选择一个[a,b)范围内定义的浮点数

normalvariate(mean,sdev):用于正态分布,其中mean是平均值,sdev用于标准偏差sigma。

使用和实例化Random创建一个独立的多个随机数生成器。

在大多数情况下,xrange和range功能完全相同。他们都提到了。了一种生成整数列表的方法,唯一的区别是range返回一个Python列表对象,x range返回一个xrange对象。这就表示xrange实际上在运行时并不是生成静态列表。它使用称为yielding的特殊技术根据需要创建值。该技术与一种称为生成器的对象一起使用。因此如果你有一个非常巨大的列表,那么就要考虑xrange。

Python中的注释以#字符开头。也可以使用doc-strings(三重引号中包含的字符串)进行注释。

Pickle模块接受任何Python对象并将其转换为字符串表示形式,并使用dump函数将其转储到文件中,此过程称为pickling。从存储的字符串中检索原始Python对象的过程称为unpickling。

返回可迭代项集的函数称为生成器。

在Python中,capitalize()函数可以将字符串的第一个字母大写。如果字符串在开头已经包含大写字母,那么它将返回原始字符串。

要将字符串转换为小写,可以使用lower()函数。

注释多行代码时。所有要注释的行都要在开头前加#。还可以使用快捷方式来注释多行,就是按住Ctrl键并在每个想要包含#字符的地方左键单击并键入一次#。

Docstrings实际上不是注释,它们是文档字符串。这些文档字符串在三引号内。它们没有分配给任何变量,因此有时也用于注释。

Operators是特殊函数,它们比较一个或多个值并产生相应的结果。其中is:当2个操作数为true时返回true(例如:“a”是’a’)

not:返回布尔值的倒数

in:检查某个元素是否存在于某个序列中

Help()和dir()这两个函数都可以从Python解释器直接访问,并用于查看内置函数的合并转储。

help()函数:help()函数用于显示文档字符串,还可以查看与模块,关键字,属性等相关的使用信息。

dir()函数:dir()函数用于显示定义的符号。

当Python退出时,尤其是那些对其他对象具有循环引用的Python模块或者从全局名称空间引用的对象并没有被解除分配或释放。

无法解除分配C库保留的那些内存部分。

退出时,由于拥有自己的高效清理机制,Python会尝试取消分配/销毁其他所有对象。

Python中的内置数据类型称为字典。它定义了键和值之间的一对一关系。字典包含一对键及其对应的值。字典由键索引。

三元运算符是用于显示条件语句的运算符。这包含true或false值,并且必须为其评估语句。其基本语法为:

三元运算符是用于显示条件语句的运算符。这包含true或false值,并且必须为其评估语句。其基本语法为:

[on_true] if [expression] else [on_false] x,y = 25,50big = x if x <y else y

Q38、为什么使用* args,* kwargs?*

当我们不确定将多少个参数传递给函数,或者我们想要将存储的列表或参数元组传递给函数时,我们使用* args。当我们不知道将多少关键字参数传递给函数时使用kwargs,或者它可以用于将字典的值作为关键字参数传递。标识符args和kwargs是一个约定,你也可以使用 bob和* billy。

len()函数可用于确定字符串,列表,数组等的长度。

如果要修改字符串,Python的“re”模块提供了3种方法。他们是:

split() – 使用正则表达式模式将给定字符串“拆分”到列表中。

sub() – 查找正则表达式模式匹配的所有子字符串,然后用不同的字符串替换它们

subn() – 它类似于sub(),并且还返回新字符串。

Python中的序列是索引的,它由正数和负数组成。积极的数字使用’0’作为第一个索引,’1’作为第二个索引,进程继续使用。

负数的索引从’-1’开始,表示序列中的最后一个索引,’ – 2’作为倒数第二个索引,序列像正数一样前进。

负索引用于从字符串中删除任何换行符,并允许该字符串除了作为S [: – 1]给出的最后一个字符。负索引还用于显示索引以正确的顺序表示字符串。

Python包是包含多个模块的命名空间。

要在Python中删除文件,您需要导入OS模块。之后,您需要使用os.remove()函数。

Python中的内置类型如下:整型、浮点型、复数、字符串、布尔等。

Python的列表是高效的通用容器。它们支持(相当)有效的插入,删除,追加和连接,Python的列表推导使它们易于构造和操作。

它们有一定的局限性:它们不支持像素化加法和乘法等“向量化”操作,并且它们可以包含不同类型的对象这一事实意味着Python必须存储每个元素的类型信息,并且必须执行类型调度代码在对每个元素进行操作时。

NumPy不仅效率更高; 它也更方便。你可以免费获得大量的向量和矩阵运算,这有时可以避免不必要的工作。它们也得到有效实施。

NumPy数组更快,你可以使用NumPy,FFT,卷积,快速搜索,基本统计,线性代数,直方图等内置。

可以使用append(),extend()和insert(i,x)函数将元素添加到数组中。

可以使用pop()或remove()方法删除数组元素。这两个函数之间的区别在于前者返回已删除的值,而后者则不返回。

Python是一种面向对象的编程语言。这意味着可以通过创建对象模型在python中解决任何程序。同时Python可以被视为程序语言和结构语言。

在创建新实例类型时使用浅拷贝,并保留在新实例中复制的值。浅拷贝用于复制引用指针,就像复制值一样。这些引用指向原始对象,并且在类的任何成员中所做的更改也将影响它的原始副本。浅拷贝允许更快地执行程序,它取决于所使用的数据的大小。

深拷贝用于存储已复制的值。深拷贝不会将引用指针复制到对象。它引用一个对象,并存储一些其他对象指向的新对象。原始副本中所做的更改不会影响使用该对象的任何其他副本。由于为每个被调用的对象创建了某些副本,因此深拷贝会使程序的执行速度变慢。

Python有一个多线程库,但是用多线程来加速代码的效果并不是那么的好,

Python有一个名为Global Interpreter Lock(GIL)的结构。GIL确保每次只能执行一个“线程”。一个线程获取GIL执行相关操作,然后将GIL传递到下一个线程。

虽然看起来程序被多线程并行执行,但它们实际上只是轮流使用相同的CPU核心。

所有这些GIL传递都增加了执行的开销。这意味着多线程并不能让程序运行的更快。

2.Python面试题搜集(二)

2019 Python最新面试题及答案16道题

这篇文章主要介绍了2019 Python最新面试题及答案16道题 ,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

答:从三个方面来说,一对象的引用计数机制,二垃圾回收机制,三内存池机制

Python内部使用引用计数,来保持追踪内存中的对象,所有对象都有引用计数。

引用计数增加的情况:

1,一个对象分配一个新名称

2,将其放入一个容器中(如列表、元组或字典)

引用计数减少的情况:

1,使用del语句对对象别名显示的销毁

2,引用超出作用域或被重新赋值

sys.getrefcount( )函数可以获得对象的当前引用计数

多数情况下,引用计数比你猜测得要大得多。对于不可变数据(如数字和字符串),解释器会在程序的不同部分共享内存,以便节约内存。

1,当一个对象的引用计数归零时,它将被垃圾收集机制处理掉。

2,当两个对象a和b相互引用时,del语句可以减少a和b的引用计数,并销毁用于引用底层对象的名称。然而由于每个对象都包含一个对其他对象的应用,因此引用计数不会归零,对象也不会销毁。(从而导致内存泄露)。为解决这一问题,解释器会定期执行一个循环检测器,搜索不可访问对象的循环并删除它们。

Python提供了对内存的垃圾收集机制,但是它将不用的内存放到内存池而不是返回给操作系统。

1,Pymalloc机制。为了加速Python的执行效率,Python引入了一个内存池机制,用于管理对小块内存的申请和释放。

2,Python中所有小于256个字节的对象都使用pymalloc实现的分配器,而大的对象则使用系统的malloc。

3,对于Python对象,如整数,浮点数和List,都有其独立的私有内存池,对象间不共享他们的内存池。也就是说如果你分配又释放了大量的整数,用于缓存这些整数的内存就不能再分配给浮点数。

答:lambda 表达式,通常是在需要一个函数,但是又不想费神去命名一个函数的场合下使用,也就是指匿名函数

lambda函数:首要用途是指点短小的回调函数

?

lambda` `[arguments]:expression``>>> a``=``lambdax,y:x``+``y``>>> a(``3``,``11``)

答:直接使用tuple和list函数就行了,type()可以判断对象的类型

4.请写出一段Python代码实现删除一个list里面的重复元素

答:

1,使用set函数,set(list)

2,使用字典函数,

?

>>>a``=``[``1``,``2``,``4``,``2``,``4``,``5``,``6``,``5``,``7``,``8``,``9``,``0``]``>>> b``=``{}``>>>b``=``b.fromkeys(a)``>>>c``=``list``(b.keys())``>>> c

?

a``=``[``1``,``2``,``4``,``2``,``4``,``5``,``7``,``10``,``5``,``5``,``7``,``8``,``9``,``0``,``3``]``a.sort()``last``=``a[``-``1``]``for` `i inrange(``len``(a)``-``2``,``-``1``,``-``1``):``if` `last``=``=``a[i]:``del` `a[i]``else``:last``=``a[i]``print``(a)

答:赋值(=),就是创建了对象的一个新的引用,修改其中任意一个变量都会影响到另一个。

浅拷贝:创建一个新的对象,但它包含的是对原始对象中包含项的引用(如果用引用的方式修改其中一个对象,另外一个也会修改改变){1,完全切片方法;2,工厂函数,如list();3,copy模块的copy()函数}

深拷贝:创建一个新的对象,并且递归的复制它所包含的对象(修改其中一个,另外一个不会改变){copy模块的deep.deepcopy()函数}

答:try…except…except…[else…][finally…]

执行try下的语句,如果引发异常,则执行过程会跳到except语句。对每个except分支顺序尝试执行,如果引发的异常与except中的异常组匹配,执行相应的语句。如果所有的except都不匹配,则异常会传递到下一个调用本代码的最高层try代码中。

try下的语句正常执行,则执行else块代码。如果发生异常,就不会执行

如果存在finally语句,最后总是会执行。

答:pass语句不会执行任何操作,一般作为占位符或者创建占位程序,whileFalse:pass

答:列出一组数据,经常用在for in range()循环中

答:可以使用re模块中的sub()函数或者subn()函数来进行查询和替换,

格式:sub(replacement, string[,count=0])(replacement是被替换成的文本,string是需要被替换的文本,count是一个可选参数,指最大被替换的数量)

?

>>> ``import` `re``>>>p``=``re.``compile``(‘blue|white|red')``>>>``print``(p.sub(‘colour``','``blue socks ``and` `red shoes'))``colour socks ``and` `colourshoes``>>>``print``(p.sub(‘colour``','``blue socks ``and` `red shoes',count``=``1``))``colour socks ``and` `redshoes

subn()方法执行的效果跟sub()一样,不过它会返回一个二维数组,包括替换后的新的字符串和总共替换的数量

答:re模块中match(pattern,string[,flags]),检查string的开头是否与pattern匹配。

re模块中research(pattern,string[,flags]),在string搜索pattern的第一个匹配值。

?

>>>``print``(re.match(‘``super``', ‘superstition'``).span())``(``0``, ``5``)``>>>``print``(re.match(‘``super``', ‘insuperable'``))``None``>>>``print``(re.search(‘``super``', ‘superstition'``).span())``(``0``, ``5``)``>>>``print``(re.search(‘``super``', ‘insuperable'``).span())``(``2``, ``7``)

答:术语叫贪婪匹配( <.> )和非贪婪匹配(<.?> )

例如:

test

<.*> :

test

<.*?> :

答:random模块

随机整数:random.randint(a,b):返回随机整数x,a<=x<=b

random.randrange(start,stop,[,step]):返回一个范围在(start,stop,step)之间的随机整数,不包括结束值。

随机实数:random.random( ):返回0到1之间的浮点数

random.uniform(a,b):返回指定范围内的浮点数。

答:PyChecker是一个python代码的静态分析工具,它可以帮助查找python代码的bug, 会对代码的复杂度和格式提出警告

Pylint是另外一个工具可以进行codingstandard检查

答:解决方法是在function的开始插入一个global声明:

def f()

global x

答:单引号和双引号是等效的,如果要换行,需要符号(),三引号则可以直接换行,并且可以包含注释

如果要表示Let’s go 这个字符串

单引号:s4 = ‘Let’s go’

双引号:s5 = “Let’s go”

s6 = ‘I realy like“python”!'

这就是单引号和双引号都可以表示字符串的原因了

以上所述是小编给大家介绍的2019 Python最新面试题及答案16道题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持! 如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

3.Python面试题搜集(三)

Python 经典面试题(一)

一、浮点数运算

题目

判断浮点数的运行结果是否相等:

 a = 0.1 b = 0.2 c = 0.3 assert a + b == c

题目解析:

本题考查的是计算机的浮点运算知识点。不仅是 python 语言,其他的编程语言也面临同样的问题:在进行浮点运算的时候,10 进制表示方式会丢掉它的精度,造成运算结果与实际结果不符合。

这是由于底层 CPU 和运算标准通过自己的浮点单位去执行算术时的特征决定的。看似有穷的小数, 在计算机的二进制表示里却是无穷的。

所以在进行高进度浮点运算的时候一定要注意,尤其是自动化测试过程中需要进行断言非常容易出错。

题目答案:

断言失败,抛出 AssertionError 错误。

解决方案:

使用 Decimal 模块:

 from decimal import Decimal  a = 0.1 b = 0.2 c = 0.3 assert Decimal(str(a)) + Decimal(str(b)) == Decimal(str(c))

Decimal() 可以维持浮点数的精度,在金融领域和测试领域等精度要求高的行业有非常大的作用。 但是一定要注意: Decimal() 传的参数一定要是字符串类型,如果是数据类型会再次丢掉精度。

  Decimal(0.1) + Decimal(0.2) == Decimal(0.3)  # False   Decimal('0.1') + Decimal('0.2') == Decimal('0.3')  # True

二、列表的扁平化和降维

题目

有一个二维列表,降成普通的一维的。比如说柠檬班都会有学员分组,我们想通过分组信息去获取所有的学员名称。

 groups = [['huahua', 'xiaojian'], ['musen', 'yuze'], ['keyou']] # 得到结果 ['huahua', 'xiaojian', 'musen', 'yuze', 'keyou']

方法一

最简单的方式可以通过 for 循环的方式一一提取:

 names = [] for group in groups:     for name in group:         names.append(name) print(names)

方法二

但是在面试的时候可能会加一些限制,比如让你用一行代码实现,这个时候就需要对 python 基础有进一步的理解了,比如说使用 sum 函数:

 names = sum(groups, [])

非常简单就实现了同样的功能。 sum 函数为什么可以做到呢?先看一个简单的例子:

 a = sum([1,2,3])

得到的结果是 6, 也就是说, sum 函数会把一个列表里面的每个元素相加。但是 sum 函数还可以有第二个参数:开始值,默认为 0 , 所以上述过程其实可以写成:

 a = sum([1,2,3], 0) # 0 + 1 + 2 + 3

依据同样的道理,可以对列表进行降维操作:

a = sum([['yuze'], ['is'], ['a']], [])
# [] + ['yuze'] + ['is'] + ['a']
# 列表拼接

方法三

通过列表推导式也可以方便的解决:

a = [e for group in groups for e in group]

三、多重继承

class A:
    def run(self):
        print("a is running")

class B:
    def run(self):
        print("b is running")

class C(A, B):
    pass

# 会打印什么???
C().run()

多重继承经常用来出面试题。在这个考题中,C 类的父类 A 和 B 都实现了 run 方法,那在 C 的对象里到底是优先调用哪一个呢?

答案是: a running

菱形问题

class A:
    def run(self):
        print("a running")

class B(A):
    pass

class C(A):
    def run(self):
        print("C running")

class D(B, C):
    pass

# 会打印什么???
D().run()

他们的继承关系图可以简化如下,这个问题又称为菱形问题或者钻石问题:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hMhnClAk-1603255929159)(

标签: 连接器uv胶水5tj5zk连接器

锐单商城拥有海量元器件数据手册IC替代型号,打造 电子元器件IC百科大全!

锐单商城 - 一站式电子元器件采购平台