Python?避免字典和元組的多重嵌套問題
一、字典、元組的多重嵌套
例 1:記錄全班學(xué)生的成績(jī)。
分析:定義一個(gè) SimpleGradebook類,
學(xué)生名是字典self._grades
的鍵,成績(jī)是字典self._grades
的值。
class SimpleGradebook(): def __init__(self): self._grades = {} def add_student(self, name): self._grades[name] = [] def report_grade(self, name, score): self._grades[name].append(score) def average_grade(self, name): grades = self._grades[name] return self._grades, sum(grades) / len(grades)
book = SimpleGradebook() book.add_student('qinlu') book.report_grade('qinlu', 99) print(book.average_grade('qinlu'))
({'qinlu': [99]}, 99.0)
字典可能因?yàn)楣δ苓^多導(dǎo)致結(jié)果多重嵌套。
例 2:擴(kuò)充 SimpleGradebook類,按科目保存成績(jī)。
分析:定義一個(gè) BySubjectGradebook類,字典by_subject
嵌套在字典self._grades
內(nèi)。
學(xué)生名是字典self._grades
的鍵,科目、成績(jī)是self._grades
的值。
科目是字典by_subject
的鍵,成績(jī)是字典by_subject
的值。
class BySubjectGradebook(): """ report_grade(), average_grade()嵌套了兩層的字典 """ def __init__(self): self._grades = {} def add_student(self, name): self._grades[name] = {} def report_grade(self, name, subject, score): by_subject = self._grades[name] grade_list = by_subject.setdefault(subject, []) grade_list.append(score) def average_grade(self, name): by_subject = self._grades[name] total, count = 0, 0 for scores in by_subject.values(): total += sum(scores) count += len(scores) return self._grades, total / count
book = BySubjectGradebook() book.add_student('qinlu') book.report_grade('qinlu', 'Math', 99) book.report_grade('qinlu', 'Math', 88) book.report_grade('qinlu', 'Computer', 90) book.report_grade('qinlu', 'Computer', 80) print(book.average_grade('qinlu'))
({'qinlu': {'Math': [99, 88], 'Computer': [90, 80]}}, 89.25)
例 3:需求變更,需記錄每次成績(jī)占總成績(jī)的權(quán)重。(期中、期末考試所占的分量比隨堂考大)
class WeightedGradebook(): def __init__(self): self._grades = {} def add_student(self, name): self._grades[name] = {} def report_grade(self, name, subject, score, weight): by_subject = self._grades[name] grade_list = by_subject.setdefault(subject, []) grade_list.append(score, weight) def average_grade(self, name): by_subject = self._grades[name] score_sum, score_count = 0, 0 for subject, scores in by_subject.items(): subject_avg, total_weight = 0, 0 for score, weight in scores: #... return score_sum / score_count
該代碼出現(xiàn)字典、元組的多層嵌套,應(yīng)拆解為類。多層嵌套的代碼,很難維護(hù)。
二、嵌套結(jié)構(gòu)重構(gòu)為類
將下面的字典重構(gòu)為類。
字典by_subject
嵌套在字典self._students
內(nèi)。
{'qinlu': {'Math': [(99, 0.1), (88, 0.9)], 'Computer': [(90. 0.1), (80, 0.9)]}}
分析:
① Gradebook()類,學(xué)生名是字典self._students
的鍵;科目、成績(jī)、權(quán)重是self._grades
的值。
② Student()類,科目是字典self._subjects
的鍵;成績(jī)、權(quán)重是self._subjects
的值。
③ Subject()類,成績(jī)是列表self._grades
的第一位;權(quán)重是列表self._grades
的第二位。
從最底層開始重構(gòu),即考試成績(jī)。這么簡(jiǎn)單的信息,沒必要寫成類。
namedtuple()命名元組。
''' 學(xué)習(xí)中遇到問題沒人解答?小編創(chuàng)建了一個(gè)Python學(xué)習(xí)交流群:711312441 尋找有志同道合的小伙伴,互幫互助,群里還有不錯(cuò)的視頻學(xué)習(xí)教程和PDF電子書! ''' from collections import namedtuple Grade = namedtuple('Grade', ('score', 'weight')) # 科目類,該類包含考試成績(jī) class Subject(): def __init__(self): self._grades = [] def report_grade(self, score, weight): self._grades.append(Grade(score, weight)) def average_grade(self): total, total_weight = 0, 0 # print(self._grades) for grade in self._grades: # print(grade) total += grade.score * grade.weight total_weight += grade.weight return total / total_weight # 學(xué)生類,該類包含學(xué)習(xí)課程 class Student(): def __init__(self): self._subjects = {} def subject(self, name): if name not in self._subjects: self._subjects[name] = Subject() return self._subjects[name] def average_grade(self): total, count = 0, 0 for subject in self._subjects.values(): total += subject.average_grade() count += 1 return total / count # 成績(jī)冊(cè)類,包含所有學(xué)生考試成績(jī)的容器類,該容器類以學(xué)生名字為鍵,可動(dòng)態(tài)添加學(xué)生 class Gradebook(): def __init__(self): self._students = {} def student(self, name): if name not in self._students: self._students[name] = Student() return self._students[name] book = Gradebook() qin = book.student('qinlu') math = qin.subject('Math') math.report_grade(99, 0.1) math.report_grade(88, 0.9) print(qin.average_grade())
89.1
雖然代碼量是原來的兩倍,但更清晰,更易擴(kuò)展,理解起來比原來容易。
到此這篇關(guān)于Python 避免字典和元組的多重嵌套的文章就介紹到這了,更多相關(guān)Python 多重嵌套內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python命令行參數(shù)解析工具 docopt 安裝和應(yīng)用過程詳解
這篇文章主要介紹了Python命令行參數(shù)解析工具 docopt 安裝和應(yīng)用過程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09python實(shí)現(xiàn)梯度法 python最速下降法
這篇文章主要為大家詳細(xì)介紹了python梯度法,最速下降法的原理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03Python基礎(chǔ)之語(yǔ)法錯(cuò)誤和異常詳解
Python有兩種錯(cuò)誤很容易辨認(rèn):語(yǔ)法錯(cuò)誤和異常.本文就給大家詳細(xì)介紹一下Python錯(cuò)誤和異常,對(duì)正在學(xué)習(xí)python的小伙伴們很有幫助哦,需要的朋友可以參考下2021-05-05django修改models重建數(shù)據(jù)庫(kù)的操作
這篇文章主要介紹了django修改models重建數(shù)據(jù)庫(kù)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-03-03python 去除txt文本中的空格、數(shù)字、特定字母等方法
今天小編就為大家分享一篇python 去除txt文本中的空格、數(shù)字、特定字母等方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-07-07pandas中DataFrame多層索引的實(shí)現(xiàn)
本文主要介紹了pandas中DataFrame多層索引的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-12-12