Day-15 - 作業(2018-10-19)
0.定義一個學生類。有屬性:姓名、年齡、成績(語文,數學,英語)[每課成績的型別為整數]
方法: a. 獲取學生的姓名:getname() b. 獲取學生的年齡:getage()
c. 返回3門科目中最高的分數。get_course()
class Student:
"""學生"""
def __init__(self, name: str, age: int=0):
self.__name = name
self.__age = age
self._chinese_score = 0
self._math_score = 0
self._english_score = 0
def get_name(self):
return self.__name
def get_age(self):
return self.__age
@property
def chinese_score(self):
return self._chinese_score
@chinese_score.setter
def chinese_score(self, score):
if not isinstance(score, int):
raise TypeError
if not 0<=score<=100:
raise ValueError
self._chinese_score = score
@property
def math_score(self):
return self._math_score
@math_score.setter
def math_score(self, score):
if not isinstance(score, int):
raise TypeError
if not 0 <= score <= 100:
raise ValueError
self._math_score = score
@property
def english_score(self):
return self._english_score
@english_score.setter
def english_score(self, score):
if not isinstance(score, int):
raise TypeError
if not 0 <= score <= 100:
raise ValueError
self._english_score = score
def get_course(self):
return max([self._chinese_score, self._math_score, self._english_score])
stu1 = Student('小明', 20)
print(stu1.get_name()) # 小明
print(stu1.get_age()) # 20
# stu1.chinese_score = 101 # ValueError
stu1.chinese_score = 90
stu1.math_score = 88
stu1.english_score = 92
print(stu1.get_course()) # 92
1.建立一個汽車類Auto,包括輪胎個數,汽車顏色,車身重量,速度等成員變數,並通過不同的構造方法建立例項。
至少要求 汽車能夠加速 減速 停車。 再定義一個小汽車類CarAuto 繼承Auto 並新增空調、CD等成員變數
覆蓋加速 減速的方法
2.建立一個名為User 的類,其中包含屬性firstname 和lastname ,還有使用者簡介通常會儲存的其他幾個屬性。
在類User 中定義一個名 為describeuser() 的方法,它列印使用者資訊摘要;
再定義一個名為greetuser() 的方法,它向使用者發出個性化的問候。
class User:
"""User類"""
def __init__(self, firstname, lastname, profession='戰士', weapon='劍'):
self.firstname = firstname
self.lastname = lastname
self.profession = profession
self.weapon = weapon
self._ability = 0
def describe_user(self):
print('姓名:%s%s, 職業:%s, 武器:%s, 戰鬥力:%s'\
% (self.firstname, self.lastname, self.profession, self.weapon, self.ability))
@property
def ability(self):
return self._ability
@ability.setter
def ability(self, num):
if not isinstance(num, int):
raise TypeError
self._ability = num
def greet_user(self):
if self._ability <= 5:
print('戰五渣%s%s,歡迎來到地獄模式!' % (self.firstname, self.lastname))
elif 6 <= self._ability <= 50:
print('新手%s%s,加油練級!' % (self.firstname, self.lastname))
elif 51 <= self._ability <= 100:
print('老手%s%s,祝您好運!' % (self.firstname, self.lastname))
elif 101 <= self._ability:
print('大神%s%s,您還差提鞋的嗎?我們做朋友吧!' % (self.firstname, self.lastname))
user1 = User('餘', '笑宇', '法師', '戰斧')
user1.describe_user()
user1.greet_user()
user1.ability = 20
user1.describe_user()
user1.greet_user()
user1.ability = 80
user1.describe_user()
user1.greet_user()
user1.ability = 500
user1.describe_user()
user1.greet_user()
# 姓名:餘笑宇, 職業:法師, 武器:戰斧, 戰鬥力:0
# 戰五渣餘笑宇,歡迎來到地獄模式!
# 姓名:餘笑宇, 職業:法師, 武器:戰斧, 戰鬥力:20
# 新手餘笑宇,加油練級!
# 姓名:餘笑宇, 職業:法師, 武器:戰斧, 戰鬥力:80
# 老手餘笑宇,祝您好運!
# 姓名:餘笑宇, 職業:法師, 武器:戰斧, 戰鬥力:500
# 大神餘笑宇,您還差提鞋的嗎?我們做朋友吧!
管理員是一種特殊的使用者。編寫一個名為Admin 的類,讓它繼承User類。新增一個名為privileges 的屬性,用於儲存一個由字串(如"can add post"、"can delete post"、"can ban user"等)組成的列表。編寫一個名為show_privileges()的方法,它顯示管理員的許可權。建立一個Admin 例項,並呼叫這個方法。
3.建立一個Person類,新增一個類欄位用來統計Perosn類的物件的個數
class Person:
count = 0 # 建立類欄位用來計算建立物件的個數
def __init__(self, name):
self.name = name
Person.count += 1 # __init__呼叫一次,類欄位count加1
p1 = Person('paul')
p2 = Person('hardon')
p3 = Person('anthony')
p4 = Person('gordon')
p5 = Person('tuck')
p6 = Person('kahuang')
print(Person.count) # 6
(嘗試)5.寫一個類,其功能是:1.解析指定的歌詞檔案的內容 2.按時間顯示歌詞 提示:歌詞檔案的內容一般是按下面的格式進行儲存的。歌詞前面對應的是時間,在對應的時間點可以顯示對應的歌詞
[00:00.20]藍蓮花
[00:00.80]沒有什麼能夠阻擋
[00:06.53]你對自由地嚮往
[00:11.59]天馬行空的生涯
[00:16.53]你的心了無牽掛
[02:11.27][01:50.22][00:21.95]穿過幽暗地歲月
[02:16.51][01:55.46][00:26.83]也曾感到彷徨
[02:21.81][02:00.60][00:32.30]當你低頭地瞬間
[02:26.79][02:05.72][00:37.16]才發覺腳下的路
[02:32.17][00:42.69]心中那自由地世界
[02:37.20][00:47.58]如此的清澈高遠
[02:42.32][00:52.72]盛開著永不凋零
[02:47.83][00:57.47]藍蓮花
class Lyric:
"""歌詞"""
def __init__(self):
self.words = ''
self.minite = '00'
self.second = '00.00'
class LyricFile:
"""歌詞檔案"""
def __init__(self):
self.lyrics = [] # 物件屬性為歌詞類Lyric型別的物件
# 定義讀取檔案的靜態方法
@staticmethod
def get_lines():
with open('./files/lyric.txt', 'r', encoding='utf-8') as f:
lines = f.readlines()
return lines
# 定義解析檔案,並返回一句句歌詞物件的物件方法
def analysis(self):
lines = LyricFile.get_lines()
for line in lines:
str1 = line
str2 = str1.replace('[', '*')
str3 = str2.replace(']', '*')
list1 = str3.split('*')
words = list1[-1]
for item in list1[:-1]:
if item:
list2 = item.split(':')
minite = list2[0]
second = list2[1]
lyric1 = Lyric()
lyric1.words = words
lyric1.minite = minite
lyric1.second = second
self.lyrics.append(lyric1)
# 按照順序列印歌詞
def show_lyrics(self):
self.lyrics.sort(key= lambda item: float(item.minite)*60 + float(item.second))
for lyric in self.lyrics:
print(lyric.words)
# 定義一個物件方法,獲取輸入時間對應的歌詞
def get_lyric_by_time_stamp(self, time_stamp: str):
list1 = time_stamp.split(':')
minite1 = list1[0]
second1 = list1[1]
time1 = float(minite1)*60 + float(second1)
self.lyrics.sort(reverse=True, key=lambda item: float(item.minite) * 60 + float(item.second))
for lyric in self.lyrics:
lyric_time = float(lyric.minite)*60 + float(lyric.second)
if time1 >= lyric_time:
return lyric.words
else:
return '歌曲蓄力中!'
lyric1 = LyricFile()
lyric1.analysis()
lyric1.show_lyrics()
print(lyric1.get_lyric_by_time_stamp('00:00.01'))
print(lyric1.get_lyric_by_time_stamp('02:01.03'))
print(lyric1.get_lyric_by_time_stamp('02:43.03'))
# 藍蓮花
#
# 沒有什麼能夠阻擋
#
# 你對自由地嚮往
#
# 天馬行空的生涯
#
# 你的心了無牽掛
#
# 穿過幽暗地歲月
#
# 也曾感到彷徨
#
# 當你低頭地瞬間
#
# 才發覺腳下的路
#
# 心中那自由地世界
#
# 如此的清澈高遠
#
# 盛開著永不凋零
#
# 藍蓮花
# 穿過幽暗地歲月
#
# 也曾感到彷徨
#
# 當你低頭地瞬間
#
# 才發覺腳下的路
#
# 穿過幽暗地歲月
#
# 也曾感到彷徨
#
# 當你低頭地瞬間
#
# 才發覺腳下的路
#
# 心中那自由地世界
#
# 如此的清澈高遠
#
# 盛開著永不凋零
#
# 藍蓮花
#歌曲蓄力中!
# 當你低頭地瞬間
#
# 盛開著永不凋零
(選做)6.使用物件導向做一個遊戲(打飛機和坦克,以及自己設計一個都行)
相關文章
- python基礎day-15:time、hash、jsonPythonJSON
- 作業系統 作業5作業系統
- 作業
- 【團隊作業】第三週作業1
- 作業系統(一):作業系統概述作業系統
- 作業系統(1)——作業系統概述作業系統
- 作業四
- 作業三
- 作業二
- 作業01
- 作業一
- 作業1
- python作業Python
- 作業2
- 2024.6.27作業
- 作業7
- 2024.6.24作業
- 2024.6.20作業
- 2024.6.21作業
- 2024.3.15作業
- 2024.3.14作業
- 2024.3.13作業
- 2024.3.12作業
- 2024.4.25作業
- 2024.4.28作業
- 2024.4.12作業
- 2024.4.16作業
- 2024.5.7作業
- 2024.4.19作業
- 2024.4.10作業
- 2024.6.18作業
- 2024.5.28作業
- 2024.5.30作業
- 2024.5.24作業
- 2024.6.13作業
- 2024.6.6作業
- 2024.6.5作業
- 2024.6.11作業