z=x
x=y
y=z
A.10,20,30 B.10,20,20 C.20,10,10 D.20,10,30
有一个函数关系如下所示:
xyx<0x x=0xx>0x+1
下面程序段中,能正确表示上面关系的是(C)。
A.
y=x+1
ifx>=0
ifx==0:
y=x
else:
y=x-1;
B.
y=x-1
ifx!=0:
ifx>0:
y=x+1
else:
y=x
C.
ifx<=0:
ifx<0>
y=x-1
else:
y=x
else:
y=x+1
D.
y=x
ifx<=0:
ifx<0>
y=x-1
else:
y=x+1
下列Python语句正确的是(D)。A.min=xifxy?x:yC.if(x>y)printxD.whileTrue:pass
四、简答题
简述Python中pass语句的作用。Python中的pass是空语句,它的出现是为了保持程序结构的完整性。pass不做任何事情,一般用做占位语句。简述break和continue的区别。break语句用于结束整个循环;continue的作用是用来结束本次循环,紧接着执行下一次的循环。
第四章
一、单选题
当需要在字符串中使用特殊字符的时候,Python使用(A)作为转义字符。A.\B./C.#D.%下列数据中不属于字符串的是(D)。A.‘ab’B.’’‘perfect’’’C.“52wo”D.abc使用(B)符号对浮点类型的数据进行格式化。A.?.?.?.%s字符串’Hi,Andy’中,字符’A’对应的下标位置为(C)。A.1B.2C.3D.4下列方法中,能够返回某个子串在字符串中出现次数的是(C)。A.lengthB.indexC.countD.find下列方法中,能够让所有单词的首字母变成大写的方法是(B)。A.capitalizeB.titleC.upperD.ljust字符串的strip方法的作用是(A)。A.删除字符串头尾指定的字符B.删除字符串末尾的指定字符C.删除字符串头部的指定字符D.通过指定分隔符对字符串切片
二、判断题
无论使用单引号或者双引号包含字符,使用print输出的结果都一样。(√)无论input接收任何的数据,都会以字符串的方式进行保存。(√)Python中只有一个字母的字符串属于字符类型。(×)使用下标可以访问字符串中的每个字符。(√)Python中字符串的下表是从1开始的。(×)切片选区的区间范围是从起始位开始的,到结束位结束。(×)如果index方法没有在字符串中找到子串,则会返回-1。(×)
三、填空题
字符串是一种表示文本数据的类型。像双引号这样的特殊符号,需要对它进行转义输出。Python3提供了input函数从标准输入(如键盘)读入一行文本。切片指的是对操作的对象截取其中的一部分。切片选取的区间是左闭右开型的,不包含结束位的值。
四、程序分析题
阅读下面的程序,分析代码是否可以编译通过。如果编译通过,请列出运行的结果,否则说明编译失败的原因。
代码一:
num_one=input("请输入一个整数:")
num_two=input("请输入一个整数:")
ifnum_one%num_two==0:
print("验证码正确")
答:不能编译通过。因为num1和num2属于字符串类型,不能执行取余操作。
代码二:
name='SteveJobs'
print(name[6])
结果为:J
代码三:
string_example='helloworlditheima'
index=string_example.index("itheima",0,10)
print(index)
答:由于没有在字符串中找到子串,index方法默认会抛出ValueError异常。
代码四:
string_example="helloworld"
print(string_example.strip())
结果为:HelloWorld(默认删除两头的空格)
代码五:
string_example="Hello"+'Python'
print(string_example)
结果为:HelloPython
第五章
一、选择题
关于列表的说法,描述有错误的是(D)。A.list是一个有序集合,没有固定大小B.list可以存放任意类型的元素C.使用list时,其下标可以是负数D.list是不可变的数据类型以下程序的输出结果是(B)。(提示:ord(“a”)==97)
list_demo=[1,2,3,4,5,'a','b']
print(list_demo[1],list_demo[5])
A.15 B.2a C.197 D.297
执行下面的操作后,list_two的值为(C)。
list_one=[4,5,6]
list_two=list_one
list_one[2]=3
A.[4,5,6] B.[4,3,6] C.[4,5,3] D.A,B,C都不正确
阅读下面的程序:
list_demo=[1,2,1,3]
nums=set(list_demo)
foriinnums:
print(i,end="")
程序执行的结果为(D)。 A.1213 B.213 C.321 D.123
下列选项中,正确定义了一个字典的是(D)。A.a=[‘a’,1,‘b’,2,‘c’,3]B.b=(‘a’,1,‘b’,2,‘c’,3)C.c={‘a’,1,‘b’,2,‘c’,3}D.d={‘a’:1,‘b’:2,‘c’:3}下列选项中,不能使用下标运算的是(C)。A.列表B.元组C.集合D.字符串下列程序执行后输出的结果为(A)。
x='abc'
y=x
y=100
print(x)
A.abc B.100 C.97,98,99 D.以上三项均是错误的
下列删除列表中最后一个元素的函数是(B)。A.delB.popC.removeC.cut下列函数中,用于返回元祖中元素最小值的是(C)。A.lenB.maxC.minD.tuple
二、判断题
列表的索引是从0开始的。(√)通过insert方法可以在制定位置插入元素。(√)使用下标能修改列表的元素。(√)列表的嵌套指的是一个列表的元素是另一个列表。(√)通过下标索引可以修改和访问元祖的元素。(×)字典中的值只能够是字符串类型。(×)在字典中,可以使用count方法计算键值对的个数。(×)
三、填空题
Python序列类型包括字符串、列表和元组三种,字典是Python中唯一的映射类型。Python中的可变数据类型有字典和列表。在列表中查找元素时可以使用notin和in运算符。如果要从小到大的排列列表的元素,可以使用sort方法实现。元组使用圆括号存放元素,列表使用的是方括号。
四、简答题
请简述元组、列表和字典的区别。(1)、外形:列表是中括号括起来的数据;元组是圆括号括起来的数据;字典是花括号括起来的数据(2)、存储结构:列表可以存储多个不同类型的数据,以逗号分隔;元组同样能存储多个不同类型的数据,以逗号分隔;字典能存储多个键值对,以逗号分隔,键是唯一的,值是任何类型的。(3)、访问方式:列表可以通过下标索引访问元素,索引从0开始;元组可以通过下标索引访问值,索引从0开始;字典通过键来访问值。(4)、是否可变类型:列表是可变类型,元组是不可变类型,字典是可变类型。
五、程序分析题
阅读下面的程序,分析代码是否能够编译通过。如果能编译通过,请列出运行的结果,否则请说明编译失败的原因。
代码一:
tup=('a','b','c')
tup[3]='d'
print(tup)
答:程序运行错误,元组不能使用下标增加元素。
代码二:
dict_demo={'a':1,'b':2,'c':3}
print(dict_demo['a'])
结果为:1
代码三:
list_demo=[10,23,66,26,35,1,76,88,58]
list_demo.reverse()
print(list_demo[3])
list_demo.sort()
print(list_demo[3])
结果为: 1 26
第六章
一、单选题
阅读下面的程序:
deffunc():
print(x)
x=100
func()
执行上述语句后,输出的结果为(C)。 A.0B.100C.程序出现异常D.程序编译失败
下面关于函数的说法,错误的是(C)。A.函数可以减少代码的重复,使得程序更加模块化B.在不同的函数中可以使用相同名字的变量C.调用函数时,传入参数的顺序和函数定义时的顺序必须相同D.函数体中如果没有return语句,也会返回一个None值下列有关函数的说法中,正确的是(C)。A.函数的定义必须在程序的开头B.函数定义后,其中的程序就可以自动执行C.函数定义后需要调用才会执行D.函数体与关键字def必须左对齐下列函数调用使用的参数传递方式是(A)。
result=sum(num1,num2,num3)
A.位置绑定B.关键字绑定C.变量类型绑定D.变量名称绑定
使用(C)关键字创建自定义函数。A.functionB.funcC.defD.procedure使用(D)关键字声明匿名函数。A.functionB.funcC.defD.lambda
二、判断题
函数的名称可以随意命名。(×)不带return的函数代表返回None。(√)默认情况下,参数值和参数名是跟函数声明定义的顺序匹配的。(√)函数定义完成后,系统会自动执行其内部的功能。(×)函数体以冒号起始,并且是缩进格式的。(√)带有默认值的参数一定位于参数列表的末尾。(√)局部变量的作用域是整个程序,任何时候使用都有效。(×)匿名函数就是没有名字的函数。(√)
三、填空题
函数可以有多个参数,参数之间使用逗号分隔。使用return语句可以返回函数值并退出函数。通过return结束函数,从而选择性地返回一个值给调用方。函数能处理比声明时更多的参数,它们是不定长参数。在函数里面调用另外一个函数,这就是函数嵌套调用。在函数的内部定义的变量称作局部变量。全局变量定义在函数外,可以在整个程序范围内访问。如果想在函数中修改全部变量,需要在变量的前面加上global关键字。
四、简答题
请简述局部变量和全局变量的区别。局部变量:(1)、函数内部定义的变量;(2)、作用域是函数的内部。全局变量:(1)、函数外部定义的变量;(2)、作用域是整个程序。请简要说明函数定义的规则。(1)、以def关键字开头,后面接函数标识符名称和圆括号;(2)、给函数起名字的时候,规则跟变量的名字是一样的;(3)、任何传入参数和自变量必须放在圆括号中间;(4)、函数的第一行语句可以选择性地使用文档字符串—用于存放函数说明;(5)、函数内容以冒号起始,并且缩进;(6)、return[表达式]结束函数,选择性地返回一个值给调用方。不带表达式的return相当于返回None。
五、程序分析题
阅读下面的程序,分析代码是否能够编译通过。如果能编译通过,请列出运行的结果,否则请说明编译失败的原因。
代码一:
deffunc():
x=200
x=100
func()
print(x)
结果为:100
代码二:
deffunc():
globalx
x=200
x=100
func()
print(x)
结果为:200
代码三:
deffunc():
x=200
deffunc2():
print(x)
func2()
x=100
func()
print(x)
结果为: 200 100
第七章
一、单选题
关于装饰器,下列说法错误的是(B)。A.装饰器是一个包裹函数B.装饰器智能有一个参数C.通过在函数定义的面前加上@符号阿和装饰器名,使得装饰器函数生效D.如果装饰器带有参数,则必须在装饰函数的外层再嵌套一层函数下列函数中,用于使用函数对制定序列进行过滤的是(C)。A.map函数B.select函数C.filter函数D.reduce函数下列选项中,不能作为filter函数参数的是(D)。A.列表B.元组C.字符串D.整数阅读下面一段程序:
deffoo():
a=1
defbar():
a=a+1
returna
returnbar
print(foo()())
上述程序执行的结果为(A)。 A.程序出现异常 B.2 C.1 D.没有输出结果
二、判断题
闭包是内部函数对外部作用域的变量进行引用。(×)当外部函数执行结束,其内部闭包引用的变量一定会立即释放。(×)装饰器是一个变量。(×)装饰器函数至少要接收一个函数。(√)装饰器既能装饰带参数的函数,也能自己带参数。(√)如果map函数传入的两个序列个数不同,那么个数多的序列会把多余的元素删除。(×)map函数只能传递一个序列。(×)map传入函数的参数个数必须跟序列的个数一样。(√)filter传入的函数可以为None。(√)filter函数智能对序列执行过滤操作。(×)filter函数的返回值为字符串,它的序列类型一定是字符串。(√)
三、填空题
内部函数引用了外部函数作用域的变量,那么内部函数叫作闭包。装饰器本质上是一个函数。装饰器函数需要接收一个参数,这个参数表示被修饰的函数。在函数定义的前面添加装饰器名和@符号,实现对函数的包装。支持参数的装饰器函数需要再多一层内嵌函数。map函数会根据提供的函数对制定的序列做映射。map的两个序列的元素个数不一致,那么元素少的序列会以None补齐。filter函数会对制定序列执行过滤操作。filter传入的函数的返回值是布尔值。reduce传入的是带有两个参数的函数,该函数不能为None。
四、简答题
请简述闭包满足的三个条件。(1)、存在于嵌套关系的函数中;(2)、嵌套的内部函数引用了外部函数的变量;(3)、嵌套的外部函数会将内部函数名作为返回值返回。请简述装饰器的应用场景。(1)、引入日志;(2)、函数执行时间统计;(3)、执行函数前预备处理;(4)、执行函数后清理功能;(5)、权限校验;(6)、缓存。请简述map、filter、reduce函数的作用。(1)、map函数会根据提供的函数对指定的序列做映射。(2)、filter函数会对指定序列执行过滤操作。(3)、reduce函数会对参数序列中的元素进行累积。
五、程序分析题
阅读下面的程序,分析代码是否能够编译通过。如果能编译通过,请列出运行的结果,否则请说明编译失败的原因。
代码一:
deffunX():
x=5
deffunY():
nonlocalx
x+=1
returnx
returnfunY
a=funX()
print(a())
print(a())
print(a())
结果为: 6 7 8
代码二:
deffunX():
x=5
deffunY():
nonlocalx
x+=1
returnx
returnfunY
returnfunY
a=funX
print(a()())
print(a()())
print(a()())
结果为: 6 6 6
第八章
一、单选题
打开一个已有文件,然后在文件末尾添加信息,正确的打开方式为(C)。A.‘r’B.‘w’C.‘a’D.‘w+’假设文件不存在,如果使用open方法打开文件会报错,那么该文件的打开方式是下列哪种模式?(A)A.‘r’B.‘w’C.‘a’D.‘w+’假设file是文本文件对象,下列选项中,哪个用于读取一行内容?(C)A.file.read()B.file.read(200)C.file.readline()D.file.readlines()下列方法中,用于向文件中写出内容的是(B)。A.openB.writeC.closeD.read下列荣方法中,用于获取当前目录的是(D)。A.openB.writeC.GetcwdD.read下列语句打开文件的位置应该在(D)。
f=open('itheima.txt','w')
A.C盘根目录下 B.D盘根目录下 C.Python安装目录下 D.与源文件在相同的目录下
若文本文件abc.txt中的内容如下:
abcdef
阅读下面的程序:
file=open("abc.txt","r")
s=file.readline()
s1=list(s)
print(s1)
上述程序执行的结果为(C)。 A.[‘abcdef’] B.[‘abcdef’] C.[‘a’,‘b’,‘c’,‘d’,‘e’,‘f’] D.[‘a’,‘b’,‘c’,‘d’,‘e’,‘f’,’’]
二、判断题
文件打开的默认方式是只读。(√)打开一个可读写的文件,如果文件存在会被覆盖。(√)使用write方法写入文件时,数据会追加到文件的末尾。(√)实际开发中,文件或者文件夹操作都要用到os模块。(√)read方法只能一次性读取文件中的所有数据。(×)
三、填空题
打开文件对文件进行读写,操作完成后应该调用close()方法关闭文件,以释放资源。seek方法用于移动指针到制定位置,该方法中offset参数表示要偏移的字节数。使用readlines方法把整个文件中的内容进行一次性读取,返回的是一个列表。os模块中的mkdir方法用于创建文件夹。在读写文件的过程中,tell方法可以获取当前的读写位置。
四、简答题
请简述文本文件和二进制文件的区别。文本文件存储的是常规字符串,由若干文本行组成,通常每行以换行符“”结尾。二进制文件把对象内容以字节串进行存储,无法用记事本或其他普通字处理软件直接进行编辑,无法被人类直接阅读和理解,需要使用专门的软件进行解码后读取、显示、修改或执行。请简述读取文件的几种方法和区别。(1)、使用read(size)方法可以指定读取的字节数,或者读取整个文件;(2)、使用readlines方法可以把整个文件的内容进行一次性读取;(3)、使用readline方法一行一行读数据。
第九章
一、单选题
下列程序运行以后,会产生如下(B)异常。
a
A.SyntaxErrorB.NameErrorC.IndexErrorD.KeyError
下列选项中,(C)是唯一不再运行时发生的异常。A.ZeroDivisionErrorB.NameErrorC.SyntaxErrorD.KeyError当try语句中没有任何错误信息时,一定不会执行(D)语句。A.tryB.elseC.finalyD.except在完整的异常语句中,语句出现的顺序正确的是(D)。A.try---->except----->else---->finallyB.try---->else---->except----->finallyC.try---->except----->finally—>elseD.try----->else---->else----->except下列选项中,用于触发异常的是(A)。A.tryB.catchC.raiseD.except关于抛出异常的说法中,描述错误的是(C)。A.当raise指定异常的类名时,会隐式地创建异常类的实例B.显式地创建异常类实例,可以使用raise直接引发C.不带参数的raise语句,只能引发刚刚发生过的异常D.使用raise抛出异常时,无法指定描述信息关于抛出异常的说法中,描述错误的是(D)。A.当raise指定异常的类名时,会隐式地创建异常类的实例B.显式地创建异常类实例,可以使用raise直接引发C.不带参数的raise语句,只能引发刚刚发生过的异常D.使用raise抛出异常时,无法指定描述信息
二、判断题
默认情况下,系统检测到错误后会终止程序。(√)在使用异常时必须先导入exceptions模块。(×)一个try语句只能对应一个except子句。(×)如果except子句没有指明任何异常类型,则表示捕捉所有的异常。(√)无论程序是否捕捉到异常,一定会执行finally语句。(√)所有的except子句一定在else和finally的前面。(√)
三、填空题
Python中所有的异常类都是Exception子类。当使用序列中不存在的索引时,会引发IndexError异常。一个try语句智能对应一个finally子句。当约束条件不满足时,assert语句会触发AssertionError异常。如果在没有except的try语句中使用else语句,会引发语法错误。
四、简答题
请简述什么是异常。在Python中,程序在执行的过程中产生的错误称为异常,比如列表索引越界、打开不存在的文件等。处理异常有哪些方式?try、except、else、finally语句。
第十章
一、单选题
下列关键字中,用来引入模块的是(C)。A.includeB.fromC.importD.continue关于引入模块的方式,错误的是(D)。A.importmathB.fromfibimportfibnacciC.formmathimport*D.from*importfib关于__name__的说法,下列描述错误的是(A)。A.它是Python提供的一个方法B.每个模块内部都有一个__name__属性C.当它的值为’__main__‘时,表示模块自身在运行D.当它的值不为’__main__'时,表示模块被引用
二、判断题
Python解释器会优先查看默认的路径搜索模块的位置。(×)每个Python文件就是一个模块。(√)当__name__属性的值为__main__时,代表该模块自身在运行。(√)包目录下必须有一个__init__py文件。(√)外部模块都提供了自动安装的文件,直接双击安装就行。(×)
三、填空题
要调用random模块的randint函数,书写形式为random.randint。每个Python文件都可以作为一个模块,模块的名字就是文件的名字。每个模块都有一个__name__属性,使程序块智能在模块自身运行时执行。为了更好地组织模块,通常会把多个模块放在一个包中。当程序中需要引入外部模块时,需要从外面下载并安装。如果要搜索模块的路径,可以使用sys模块的path变量。
四、简答题
解释Python脚本程序的"__name__"的作用。每个Python脚本在运行时都有一个“__name__”属性。如果脚本作为模块被导入,则其“__name__”属性的值被自动设置为模块名;如果脚本独立运行,则其“__name__”属性值被自动设置为“__name__”属性。利用“__name__”属性即可控制Python程序的运行方式。请简述Python解释器搜索模块位置的顺序。(1)、搜索当前目录,如果不在当前目录,Python则搜索在shell变量PYTHONPATH下的每个目录。(2)、如果都找不到。Python会继续查看默认路径。请简述模块的概念。在Python中有一个概念叫做模块(module),这个和C语言中的头文件以及Java中的包很类似,比如在Python中要调用sqrt函数,必须用import关键字引入math这个模块。请简述导入模块的方法。在Python中用关键字import来引入某个模块:(1)、导入模块,使用“import模块”引入;(2)、导入模块中的某个函数,使用“from模块名import函数名”引入;(3)、导入模块的全部内容,使用“from模块import*”。
第十一章
一、单选题
关于面向过程和面向对象,下列说法错误的是(B)。A.面向过程和面向对象都是解决问题的一种思路B.面向过程是基于面向对象的C.面向过程强调的是解决问题的步骤D.面向对象强调的是解决问题的对象关于类和对象的关系,下列描述正确的是(D)。A.类和面向对象的核心B.类是现实中事物的个体C.对象是根据类创建的,并且一个类只能对应一个对象D.对象描述的是现实的个体,它是类的实例构造方法的作用是(C)。A.一般成员方法B.类的初始化C.对象的初始化D.对象的建立构造方法是类的一个特殊方法,Python中它的名称为(C)。A.与类同名B._constructC._init_D.initPython类中包含一个特殊的变量(A),它表示当前对象自身,可以访问类的成员。A.selfB.meC.thisD.与类同名下列选项中,符合类的命名规范的是(A)。A.HolidayResortB.HolidayResortC.hoildayResortD.hoilidayresortPython中用于释放类占用资源的方法是(B)。A.__init__B.__del__C._delD.delete
二、判断题
面向对象是基于面向过程的。(×)通过类可以创建对象,有且只有一个对象实例。(×)方法和杉树的格式是完全一样的。(×)创建类的对象时,系统会自动调用构造方法进行初始化。(√)创建完对象后,其属性的初始值是固定的,外界无法进行修改。(×)使用del语句删除对象,可以手动释放它所占用的资源。(√)
三、填空题
在Python中,可以使用class关键字来声明一个类。面向对象需要把问题划分多个独立的对象,然后调用其方法解决问题。类的方法中必须有一个self参数,位于参数列表的开头。Python提供了名称为__init__的构造方法,实现让类的对象完成初始化。如果想修改属性的默认值,可以在构造方法中使用参数设置。
四、简答题
请简述self在类中的意义。不用实例化对象就能够在本类中访问自身的属性或方法。类是由哪三个部分组成的?类名,属性,方法。请简述构造方法和析构方法的作用。分别用于初始化对象的属性和释放类所占用的资源。
五、程序分析题
阅读下面的程序,分析代码是否能够编译通过。如果能编译通过,请列出运行的结果,否则请说明编译失败的原因。
代码一:
classPerson:
def__init__(self,name):
self.name=name
def__str__(self):
return"我的名字是"+self.name
person=Person("小明")
print(person)
结果为:我的名字是小明
代码二:
classPerson:
def__del__(self):
print("--del--")
person=Person()
delperson
print("--end--")
结果为: --del– --end–
第十二章
一、选择题
Python中定义私有属性的方法是(D)。A.使用private关键字B.使用public关键字C.使用__XX__定义属性名D.使用__XX定义属性名下列选项中,不属于面向对象程序设计的三个特征的是(A)。A.抽象B.封装C.继承D.多态以下C类继承A类和B类的格式中,正确的是(C)。A.classCA,B:B.classC(A:B)C.classC(A,B)D.classCAandB:下列选项中,与classPerson等价的是(C)。A.classPerson(Object)B.classPerson(Animal)C.classPerson(object)D.classPerson:object下列关于类属性和示例属性的说法,描述正确的是(B)。A.类属性既可以显示定义,又能在方法中定义B.公有类属性可以通过类和类的实例访问C.通过类可以获取实例属性的值D.类的实例只能获取实例属性的值下列选项中,用于标识为静态方法的是(C)。A.@classmethoodB.@instancemethodC.@staticmethodD.@privatemethod下列方法中,不可以使用类名访问的是(A)。A.实例方法B.类方法C.静态方法D.以上3项都不符合
二、判断题
Python中没有任何关键字区分公有属性和私有属性。(√)继承会在原有类的基础上产生新的类,这个新类就是父类。(×)带有两个下划线的方法一定是私有方法。(√)子类能继承父类的一切属性和方法。(×)子类通过重写继承的方法,覆盖掉跟父类同名的方法。(√)如果类属性和实例属性重名,对象有限访问类属性的值。(×)使用类名获取到的值一定是类属性的值。(√)静态方法中一定不能访问实例属性的值。(√)
三、填空题
如果属性名的前面加上了两个下划线,就表明它是私有属性。在现有类基础上构建新类,新的类称作子类,现有的类称作父类。父类的私有属性和方法是不能被子类继承的,更不能被子类访问。Python语言既支持单继承,也支持多继承。子类想按照自己的方式实现方法,需要重写从父类继承的方法。子类通过super()可以成功地访问父类的成员。位于类内部、方法外部的方法是类方法。类方法是类拥有的方法,使用修饰器@classmethod来标识。
四、简答题
请简述如何保护类的属性。(1)、把属性定义为私有属性,即在属性名的前面加上两个下划线;(2)、添加用于设置或者获取属性值的两个方法供外界调用。什么是继承?类的继承是指在一个现有类的基础上构建一个新的类,构建出来的新类被称作子类,现有类被称作父类,子类会自动拥有父类的属性和方法。请简述私有属性无法访问的原理。当在一个类的内部定义了私有方法或者私有属性的时候,Python在运行的过程中,把属性或者方法的名字进行了修改,即在属性或者方法名称的前面加上“_类名”,导致原有的方法无法访问到。什么是多态?在Python中,多态是指在不考虑对象类型的情况下使用对象。请简述实例方法、类方法和静态方法的区别。(1)、类方法需要使用@classmethod进行标识,该方法可以访问类属性,无法访问实例属性,可以通过类实例和类进行调用。(2)、静态方法使用@staticmethod进行标识,该方法无法访问实例属性和类属性,起到类似于函数的作用,使用类或者类实例进行调用。(3)、实例方法直接在类中使用def进行定义,可以访问其实例属性和类属性,使用类实例进行调用。(4)、如果要修改实例属性的值,就直接使用实例方法;如果要修改类属性的值,就直接使用类方法;如果是辅助功能,比如打印菜单,这时可以考虑使用静态方法,可以在不创建对象的前提下使用。请简述Python中以下划线开头的变量名的特点。在Python中,以下划线开头的变量名有着特殊的含义,尤其是在类的定义中。用下划线作为变量前缀和后缀来表示类的特殊成员:(1)、_xx:这样的对象叫做保护变量,不能用frommoduleimport*导入,只有类对象和子类对象能够访问这些变量。(2)、__xx__:系统定义的特殊成员名字。(3)、__xx:类中的私有成员,只有类对象自己能访问,子类对象也不能访问到这个成员,但在对象外部可以通过“对象名.__类名__xx”这样特殊的方式来访问。Python中没有纯粹的C++意义上的私有成员。
END
如果本文有什么写的不对的地方或有什么更好地建议和想法,欢迎在下方评论留言或私信我,大家一起进步学习!