要求:分別以james,julie,mikey,sarah四個學生的名字建立文本文件,分別存儲各自的成績,時間格式都精確為分秒,時間越短成績越好,分別輸出每個學生的無重復的前三個最好成績,且分秒的分隔符要統一為“.”
數據準備:分別建立四個文本文件
james.txt 2-34,3:21,2.34,2.45,3.01,2:01,2:01,3:10,2-22
julie.txt 2.59,2.11,2:11,2:23,3-10,2-23,3:10,3.21,3-21
mikey.txt 2:22,3.01,3:01,3.02,3:02,3.02,3:22,2.49,2:38
sarah.txt 2:58,2.58,2:39,2-25,2-55,2:54,2.18,2:55,2:55
代碼實現:
代碼如下:
import os
os.chdir('C:/Python33/HeadFirstPython/hfpy_code/chapter5') #將工作空間修改為文件所在的目錄
#定義函數get_filedata從文件中取值
def get_filedata(filename):
try:
with open(filename) as f: #with語句打開和自動關閉文件
data=f.readline() #從文件中逐行讀取字符
return (data.strip().split(',')) #將字符間的空格清除后,用逗號分隔字符
except IOError as ioerr:
print ('File Error' + str(ioerr)) #異常處理,打印錯誤
return (None)
#定義函數modify_time_format將所有文件中的時分表達方式統一為“分.秒”
def modify_time_format(time_string):
if "-" in time_string:
splitter="-"
elif ":" in time_string:
splitter=":"
else:
splitter="."
(mins, secs)=time_string.split(splitter) #用分隔符splitter分隔字符后分別存入mins和secs
return (mins+ '.' +secs)
#定義函數get_prev_three返回文件中排名前三的不重復的時間成績
def get_prev_three(filename):
new_list=[modify_time_format(each_t) for each_t in get_filedata(filename)] #采用列表推導將統一時分表達方式后的記錄生成新的列表
delete_repetition=set(new_list) #采用集合set函數刪除新列表中重復項,并生成新的集合
新聞熱點
疑難解答