python – 可扩展程序的良好设计模式
我有一个关于如何为我的程序设计好的问题.我的程序非常简单,但我希望拥有良好的架构,并使我的程序在未来易于扩展. 我的程序需要从外部数据源(XML)获取数据,从这些数据中提取信息,最后需要准备SQL语句以将信息导入数据库.因此,对于现在存在的所有外部数据源,将来会有我的应用程序的简单“流程”:获取,提取和加载. 我正在考虑创建名为DataFetcher,DataExtractor和DataLoader的泛型类,然后编写将继承它们的特定类.我想我需要一些工厂设计模式,但是哪个? FactoryMethod还是抽象工厂? 我也想不要使用这样的代码: if data_source == 'X': fetcher = XDataFetcher() elif data_source == 'Y': fetcher = YDataFetcher() .... 理想情况下(我不确定这是否容易实现),我想编写新的“数据源处理器”,在现有代码中添加一行或两行,我的程序将从新数据源加载数据. 如何利用设计模式来实现目标?如果您可以在python中提供一些示例,那就太棒了. 解决方法如果取出器都具有相同的接口,则可以使用字典:fetcher_dict = {'X':XDataFetcher,'Y':YDataFetcher} data_source = ... fetcher = fetcher_dict[data_source]() 保持灵活性 – 只需编写干净的惯用代码即可.我倾向于喜欢“你不需要它”(YAGNI)哲学.如果您花费太多时间来展望未来以找出您将需要的东西,那么当您找到实际需要的内容时,您的代码将变得过于臃肿和复杂,无法进行简单的调整.如果代码是清理的,那么以后应该很容易重构以满足您的需求. (编辑:甘南站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 什么python代码为二元运算符生成所有可能的分组(树)
- python – django中的高效分页和数据库查询
- python – J的x型变量:它们如何在内部存储?
- python – 为什么time.clock比time.time给出更长的时间?
- python – 如何访问`pip –user`安装的软件包?
- python – 迭代工作表,行,列
- python – 具有超类类名称的子类变量
- python – 是否有任何方法可以使用openpyxl获取.xlsx表中存
- python – 从Azure ML中的pyodbc连接到Azure SQL数据库的驱
- python – Flask:后台线程看到一个非空队列为空