Day 31 面向对象考试题 第四次考试.
一 基础知识和函数:
1.文件操作有哪些模式?请简述各模式的作用
r ,只读模式【默认模式,文件必须存在,不存在则抛出异常】
w,只写模式【不可读;不存在则创建;存在则清空内容】
x, 只写模式【不可读;不存在则创建,存在则报错】
a, 追加模式【可读; ? 不存在则创建;存在则只追加内容】
"+" 表示可以同时读写某个文件
r+, 读写【可读,可写】
w+,写读【可读,可写】
x+ ,写读【可读,可写】
a+, 写读【可读,可写】
"b"表示以字节的方式操作
rb 或 r+b
wb 或 w+b
xb或 w+b
ab或 a+b
2.s = '**hello,world!**'请使用strip方法去掉字符串两端的'*'号
3.用户输入一个任意数字n,求1-n之间所有数字中的奇数
4.s = 'hskakhlkshfkskjakf',请去除s字符串中重复的字母
s = 'hskakhlkshfkskjakf'
x=''
for i in s:
if i not in x:
x+=i
print(x)
5.a=10
b=20
def test5(a,b):
print(a,b)
c = test(b,a)
print(c)
上述代码中,打印出来的值a,b,c分别是什么?为什么?
6.s = '123.33sdhf3424.34fdg323.324',计算字符串中所有数字的和
本题结果应为:123.33+3424.34+323.32
7.d={'k1':'v1','k2':[1,2,3],('k','3'):{1,2,3}}
请用程序实现:
1)输出上述字典中value为列表的key
2)如果字典中的key是一个元祖,请输出对应的value值。
3)d[('k','3')]对应的value是一个什么数据类型
8.如果不使用@wrapper装饰器,请在a()之前加入一句代码,达到相同的效果
def wrapper(func):
def inner(*arg, **kwargs):
func(*arg, **kwargs)
return inner
#@wrapper
def a(arg):
print(arg)
9.请处理文件7th_questions,输出所有以'T'开头的行
10.读登陆.zip文件中的代码,请为这段代码画流程图
11 默写字符串对象的内置方法,越多越好
二 面向对象
1.请简述类、对象、实例化、实例这些名词的含义:
类: 类是对有相同属性和相似行为的一类事物的抽象。
对象: 是一个具有具体属性值的类的实例化.
实例化 :从一个抽象的类产生一个具体对象的过程.
实例:就是对象.
2.面向对象的三大特性是什么?
继承 ,多态,封装
3.什么是方法?类中可以定义哪几种方法?
在类中的函数就是方法 ,描述一类事物的行为。
类方法 ,静态方法 私有方法 内置方法 ,属性方法(@property)
4.什么是属性?类中可以定义哪几种属性?
类和对象所拥有的具体的‘值 ’指标
静态属性 ,私有属性 动态属性 (方法) 对象属性.
5.请简述类方法和静态方法有哪些区别?
装饰器不同 @staticmethod @ classmethod
类方法中有一个默认的参数,clas, 而静态方法没有.
6.请简述新式类和经典类的区别?
经典类 遵循深度优先算法并且没有mro方法 用在python2中
新式类 遵循广度优先算法 有 mor方法 用在python2 和python3中.
7.有一个类定义:
class Person:
def __init__(self,name,age):
self.name = name
self.age = age
1)初始化10个不同的对象
2)求最高age的对象的name
8. 模拟cs游戏
人物角色分为警察和匪徒两种,定义成两个类
所有的警察的角色都是police
每个警察都有自己独有名字,生命值,武器,性别
每个都可以开枪攻击敌人,切攻击目标不能是police
所有的警察的角色都是terrorist
每个匪徒都有自己独有名字,生命值,武器,性别
每个都可以开枪攻击敌人,切攻击目标不能是terrorist
# class Police: #类名 Police
# def __init__(self,name,value,weapon,sex): #动态属性
# self.name =name #对象属性,实例化属性
# self.value =value
# self.weapon =weapon
# self.sex =sex
# def attck(self,enemy): #自定义方法
# print('%s作为警察攻击了 %s ' %(self.name,enemy.name) )
# enemy.value -=self.weapon
# class Terrorsit: #类名Terrorist
# def __init__(self,name,value,weapon,sex):
# self.name =name
# self.value =value
# self.weapon =weapon
# self.sex =sex
# def kill(self,police):
# print('%s 作为敌人攻击了%s'%(self.name,police.name))
# police.value -= self.weapon
9. 实例化一个警察,一个匪徒,警察攻击匪徒,匪徒掉血
# policeman_alex = Police('alex' ,100,20, 'male')
# terrorist_egon = Terrorsit('egon',800,30,'male')
# policeman_alex.attck(terrorist_egon)
# print(terrorist_egon.value)
# 输出结果为
# alex作为警察攻击了 egon
# 780
10. 提取警察类和匪徒类相似之处定义成一个父类,使用继承的方式减少代码重复
class Person:#定义一个父类.
def __init__(self,name,value,weapon,sex):
self.name =name
self.value =value
self.weapon =weapon
self.sex =sex
class Police: #类名 Police 继承Person父类
def attck(self,enemy): #自定义方法
print('%s作为警察攻击了 %s ' %(self.name,enemy.name) )
enemy.value -=self.weapon
class Terrorsit: #类名Terrorist ,继承Person父类
def kill(self,police):
print('%s 作为敌人攻击了%s'%(self.name,police.name))
police.value -= self.weapon
11.
class Base:
def f1(self):
self.f2()
def f2(self):
print('...')
class Foo(Base):
def f2(self):
print('9999')
obj = Foo()
obj.f1()
问题1:面向对象中的self指的什么?
问题2:运行结果并简述原因
思考题:
有一个类的init方法如下:
class Person:
def __init__(self,name,age,sex,weight):
self.name = name
self.sex = sex
self.age = age
self.weight = weight
假设有100个person的对象,
若两个对象的obj1,obj2的name和sex属性相同
即obj1.name==obj2.name and obj1.sex==obj2.sex
我们认为两个对象为同一个对象,已知一个列表中的100个对象,对这100个对象进行去重。
提示:
重写Person类重的两个内置方法
class Person:#定义一个类 def __init__(self,name,age,sex): #初始化属性 self.name = name #对象的name属性 self.age = age #对象的age属性 self.sex = sex #对象的sex属性 def __hash__(self): #定义哈希方法 return hash('%s%s'%(self.name,self.sex)) #返回hash'self.name,self.sex'的值 def __eq__(self, other): #定义一个eq方法 if self.name == other.name and \ self.sex == other.sex: #如果对象属性等于 return True p_lst = [] #定义个空列表 for i in range(100):#打印0到99 p_lst.append(Person('egon',i,'male'))#p_lst列表添加Person('egon',i,'male') p_lst.append(Person('alex',i,'male'))#p_lst列表添加Person('alex',i,'male') p_lst.append(Person('yuan',i,'male'))#p_lst列表添加Person('yuan',i,'male') print(p_lst) # print(set(p_lst)) # 报错不可hash 完成了__hash__ # hash是否相等 __hash__ # 值是否相等 __eq__ # a==b # 收获1 # 对于一些python当中已经存在的内置函数 内置数据类型 内置模块中的方法 # 都有可能依赖于类中的内置方法 # 收获2 # set方法依赖集合中元素对象的__hash__ __eq__