Q31。如何在python中注释多行?

Ans:多行注释出现在多行中。所有要评论的行都要以#为前缀。您还可以使用非常好的 快捷方式来注释多行。您需要做的就是按住Ctrl键并  在每个想要包含#字符的地方左键单击并键入一次#。这将注释您引入光标的所有行。

Q32。Python中的文档字符串是什么?

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

例:

"""
Using docstring as a comment.
This code divides 2 numbers
x=8
y=4
z=x/y
print(z)

输出: 2.0

Q33。目的是什么,不是和运营商?

Ans:操作员是特殊功能。它们采用一个或多个值并产生相应的结果。

is:当2个操作数为true时返回true(例如:“a”是'a')

not:返回布尔值的倒数

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

Q34。Python中help()和dir()函数的用法是什么?

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

  1. Help()函数:help()函数用于显示文档字符串,还可以帮助您查看与模块,关键字,属性等相关的帮助。
  2. Dir()函数:dir()函数用于显示定义的符号。

Q35。每当Python退出时,为什么不是所有的内存都被解除分配?

答: 

  1. 每当Python退出时,尤其是那些对其他对象具有循环引用的Python模块或者从全局名称空间引用的对象并不总是被解除分配或释放。
  2. 无法解除分配C库保留的那些内存部分。
  3. 退出时,由于拥有自己的高效清理机制,Python会尝试取消分配/销毁其他所有对象。

Q36。Python中的字典是什么?

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

我们来举个例子:

以下示例包含一些键。国家,资本和下午。它们的相应值分别是印度,德里和莫迪。

1dict={'Country':'India','Capital':'Delhi','PM':'Modi'}
1print dict[Country]
印度
1print dict[Capital]
新德里
1print dict[PM]
莫迪


莫迪

Q37。如何在python中使用三元运算符?

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

语法

三元运算符将被给出为:
[on_true] if [expression] else [on_false] x,y = 25,50big = x if x <y else y

例:

表达式的计算方式与x <y else y一样,在这种情况下,如果x <y为真,则返回值为big = x,如果不正确则返回big = y作为结果。

Q38。这是什么意思:* args,** kwargs?我们为什么要用呢?

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

Q39。len()做什么?

Ans:用于确定字符串,列表,数组等的长度。

例:

stg='ABCD'
len(stg)

Q40。在Python中解释“re”模块的split(),sub(),subn()方法。

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

  • split() - 使用正则表达式模式将给定字符串“拆分”到列表中。
  • sub() - 查找正则表达式模式匹配的所有子字符串,然后用不同的字符串替换它们
  • subn() - 它类似于sub(),并且还返回新字符串和no。替换。

Q41。什么是负指数,为什么使用它们?

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

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

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

Q42。 什么是Python包?

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

Q43。如何在Python中删除文件?

Ans:要在Python中删除文件,您需要导入操作系统模块。之后,您需要使用os.remove()函数。

例:

import os
os.remove("xyz.txt")

Q44。什么是python的内置类型?

Ans: Python中的内置类型如下 -

  • 整型
  • 浮点
  • 复数
  • 字符串
  • 布尔
  • 内置功能

Q45。NumPy阵列在(嵌套)Python列表中提供了哪些优势?

答: 

  1. Python的列表是高效的通用容器。它们支持(相当)有效的插入,删除,追加和连接,Python的列表推导使它们易于构造和操作。
  2. 它们有一定的局限性:它们不支持元素化加法和乘法等“向量化”操作,并且它们可以包含不同类型的对象这一事实意味着Python必须存储每个元素的类型信息,并且必须在操作时执行类型调度代码在每个元素上。
  3. NumPy不仅效率更高; 它也更方便。你可以免费获得大量的向量和矩阵运算,这有时可以避免不必要的工作。它们也得到有效实施。
  4. NumPy数组更快,你可以使用NumPy,FFT,卷积,快速搜索,基本统计,线性代数,直方图等内置。 

Q46。 如何将值添加到python数组?

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

例:

a=arr.array('d', [1.1 , 2.1 ,3.1] )

a.append(3.4)

print(a)

a.extend([4.5,6.3,6.8])

print(a)

a.insert(2,3.8)

print(a)

输出:

数组('d',[1.1,2.1,3.1,3.4])

数组('d',[1.1,2.1,3.1,3.4,4.5,6.3,6.8])

数组('d',[1.1,2.1,3.8,3.1,3.4,4.5,6.3,6.8])

Q47。如何删除python数组的值?

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

例:

a=arr.array('d', [1.1, 2.2, 3.8, 3.1, 3.7, 1.2, 4.6])

print(a.pop())

print(a.pop(3))

a.remove(1.1)

print(a)

输出:

4.6

3.1

数组('d',[2.2,3.8,3.7,1.2])

Q48。 Python有OOps概念吗?

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

Q49。深拷贝和浅拷贝有什么区别?

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

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

Q50。如何在Python中实现多线程?

答: 

  1. Python有一个多线程包,但是如果你想要多线程来加速你的代码,那么使用它通常不是一个好主意。
  2. Python有一个名为Global Interpreter Lock(GIL)的结构。GIL确保每次只能执行一个“线程”。一个线程获取GIL,做一点工作,然后将GIL传递到下一个线程。
  3. 这种情况很快发生,因此对于人眼看来,您的线程似乎并行执行,但它们实际上只是轮流使用相同的CPU核心。
  4. 所有这些GIL传递都增加了执行的开销。这意味着如果您想让代码运行得更快,那么使用线程包通常不是一个好主意。

Q51。 在python中编译和链接的过程是什么?

Ans: 编译和链接允许正确编译新扩展而不会出现任何错误,并且只有在通过编译过程时才能进行链接。如果使用动态加载,则它取决于系统提供的样式。python解释器可用于提供配置设置文件的动态加载,并将重建解释器。

这需要的步骤如下:

  1. 使用任何名称以及系统编译器支持的任何语言创建文件。例如file.c或file.cpp
  2. 将此文件放在正在使用的发行版的Modules /目录中。
  3. 在Modules /目录中存在的Setup.local文件中添加一行。
  4. 使用spam file.o运行该文件
  5. 通过在顶级目录上使用make命令成功运行此重建解释器之后。
  6. 如果文件已更改,则使用命令“make Makefile”运行rebuildMakefile。

Q52。 什么是Python库?举几个例子。

Python库是Python包的集合。一些主要使用的python库是 - NumpyPandasMatplotlibScikit-learn等等。

Q53。 什么是拆分用于?

split()方法用于在Python中分隔给定的字符串。

例:

a="edureka python"

print(a.split())

输出:  ['edureka','python']

Q54。 如何在python中导入模块?

可以使用import 关键字导入模块。您可以通过三种方式导入模块 -

例:

import array           #importing using the original module name

import array as arr    # importing using an alias name

from array import *    #imports everything present in the array module

OOPS面试问题

Q55。用一个例子解释Python中的继承。

Ans: 继承允许一个类获得另一个类的所有成员(比如属性和方法)。继承提供代码可重用性,使创建和维护应用程序更容易。我们继承的类称为超类,继承的类称为派生/子类。

它们是Python支持的不同类型的继承:

  1. 单一继承 - 派生类获取单个超类的成员。
  2. 多级继承 - 从基类base1继承的派生类d1,d2继承自base2。
  3. 分层继承 - 从一个基类可以继承任意数量的子类
  4. 多重继承 - 派生类从多个基类继承。

Q56。如何在Python中创建类? 

Ans: Python中的是使用 class关键字创建的。

例:

class Employee:

def __init__(self, name):

self.name = name

E1=Employee("abc")

print(E1.name)

输出: abc

Q57。什么是Python补丁?

Ans: 在Python中,术语猴子补丁仅指在运行时对类或模块的动态修改。

考虑以下示例:

# m.py

class MyClass:

def f(self):

print "f()"

然后我们可以像这样运行猴子补丁测试:

import m

def monkey_f(self):

print "monkey_f()"

 

m.MyClass.f = monkey_f

obj = m.MyClass()

obj.f()

输出如下:

monkey_f()

正如我们所看到的,我们确实使用我们在模块m之外  定义的函数  monkey_f()  在  MyClass中  f()的行为进行了一些更改。

Q58。python是否支持多重继承?

Ans:多重继承意味着可以从多个父类派生一个类。与Java不同,Python确实支持多重继承。

问59.Python中的多态性是什么?

答:多态性意味着能够采取多种形式。因此,例如,如果父类具有名为ABC的方法,则子类也可以具有具有相同名称ABC的方法,该方法具有其自己的参数和变量。Python允许多态。

Q60。在Python中定义封装?

Ans:封装意味着将代码和数据绑定在一起。封装示例中的Python类。