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解释器访问,并用于查看内置函数的合并转储。
- Help()函数:help()函数用于显示文档字符串,还可以帮助您查看与模块,关键字,属性等相关的帮助。
- Dir()函数:dir()函数用于显示定义的符号。
Q35。每当Python退出时,为什么不是所有的内存都被解除分配?
答:
- 每当Python退出时,尤其是那些对其他对象具有循环引用的Python模块或者从全局名称空间引用的对象并不总是被解除分配或释放。
- 无法解除分配C库保留的那些内存部分。
- 退出时,由于拥有自己的高效清理机制,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列表中提供了哪些优势?
答:
- Python的列表是高效的通用容器。它们支持(相当)有效的插入,删除,追加和连接,Python的列表推导使它们易于构造和操作。
- 它们有一定的局限性:它们不支持元素化加法和乘法等“向量化”操作,并且它们可以包含不同类型的对象这一事实意味着Python必须存储每个元素的类型信息,并且必须在操作时执行类型调度代码在每个元素上。
- NumPy不仅效率更高; 它也更方便。你可以免费获得大量的向量和矩阵运算,这有时可以避免不必要的工作。它们也得到有效实施。
- 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中实现多线程?
答:
- Python有一个多线程包,但是如果你想要多线程来加速你的代码,那么使用它通常不是一个好主意。
- Python有一个名为Global Interpreter Lock(GIL)的结构。GIL确保每次只能执行一个“线程”。一个线程获取GIL,做一点工作,然后将GIL传递到下一个线程。
- 这种情况很快发生,因此对于人眼看来,您的线程似乎并行执行,但它们实际上只是轮流使用相同的CPU核心。
- 所有这些GIL传递都增加了执行的开销。这意味着如果您想让代码运行得更快,那么使用线程包通常不是一个好主意。
Q51。 在python中编译和链接的过程是什么?
Ans: 编译和链接允许正确编译新扩展而不会出现任何错误,并且只有在通过编译过程时才能进行链接。如果使用动态加载,则它取决于系统提供的样式。python解释器可用于提供配置设置文件的动态加载,并将重建解释器。
这需要的步骤如下:
- 使用任何名称以及系统编译器支持的任何语言创建文件。例如file.c或file.cpp
- 将此文件放在正在使用的发行版的Modules /目录中。
- 在Modules /目录中存在的Setup.local文件中添加一行。
- 使用spam file.o运行该文件
- 通过在顶级目录上使用make命令成功运行此重建解释器之后。
- 如果文件已更改,则使用命令“make Makefile”运行rebuildMakefile。
Q52。 什么是Python库?举几个例子。
Python库是Python包的集合。一些主要使用的python库是 - Numpy,Pandas,Matplotlib,Scikit-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支持的不同类型的继承:
- 单一继承 - 派生类获取单个超类的成员。
- 多级继承 - 从基类base1继承的派生类d1,d2继承自base2。
- 分层继承 - 从一个基类可以继承任意数量的子类
- 多重继承 - 派生类从多个基类继承。
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类。