python高级编程之选择好名称:完2

# -*- coding: utf-8 -*-

# python:2.x

__author__ = ‘Administrator‘

#分解代码

#小就是美,这也适用所有级别的代码,当一个函数,类或者一个代码太大时,应该对其进行分解

#一个函数或者一个方法的内容不应该起过一个屏幕,也就是大约25到30行,否则它将很难跟踪和理解

#关于代码生可以参看eric raymond所著的art of unix programming(中文版<unix编码艺术>)中章节

#类的方法数量应该有一定的限制,当方法超过10个时,即使创建者对其也很难做出完整描绘,一个常见的方法是分离功能并且在该类之外创建多个类

#一个模块的大小也应该有一定的限制,当它超过500行时,应该被分解为多个模块

#这个工作将会影响API,并且意味着在包级别上需要付出被额外的工作来确保代码分解和组织的方式不会使API难以使

#换句话说,API应该问题是从用户角度来测试,以确保它可用,易于记忆和简明.

#使用Egg

"""

当应用程序不断成长时,主文件夹下面的包数量也会变大,例如,像ZOPE这样的框架在根包zope命名空间中就有超过50个包

为了避免使整个代码言库都在同一个文件夹里面,并能单独发布每个包,可以使用python eggs:http://peak.telecommnuity.com/devcenter/pythoneggs

来解决,它们提供了一个构建命名空间的包的简单方法,就像JAVA中提供的JAR一样

例如,如果希望将 acme.templates作为单独的包分发,可以使用setuptools(用于建立的python egg程序库)来构建一个基于egg的包,在acme文件夹中的特殊方法__init__.py里面添加以下内容

http://peak.telecommunity.com/devcenter/setuptools#namespace-packages

try:

__import__(‘pkg_resources‘).declare_namespace(__name__)

except ImportError:

from pkgutil import extend_path

__path__==extend._path(__path__,__name__)

然后,acme文件夹可以保存templates文件夹,并使其能够位于acme.templates命名空间之下,acme.pdf甚至可以从独立蝗acme文件夹中被分离出来

遵循相同规则,来自相同组织的包可以通过egg收集在相同命名空间中,即使它们互不相关,所有来自ingeniweb包都使用iw命名空间,并且可以使用前缀

http://pypi.python.org/pypi?%Aaction=search&term=iw/&submit=search,在cheeseshop上找到

除了命名空间之外,以egg形式分发应该程序也对模块化有帮助,因为可以视每个egg为一个独立组件

"""

#使用deprecation过程

#当包已经被发布被第三方代码使用时,对API修改就必须小心进行了,处理这种修改最简单的方法是遵循一个deprecation过程,在此是2个版本中间发行版本

#例如

class S(object):#版本1

def run_script(self,s1,s2):

print ‘work‘

import warnings

class S1(object):#版本1.5

def run_script(self,s1,s2):

print ‘work‘

warnings.warn((‘run_scriptwill‘),DeprecationWarning)

return self.run(s1,s2)

def run(self,s1,s2=None):

print ‘word‘

class S3(object):#版本2

def run(self,s1,s2=None):

pass

#warnings模块将在第一次调用时警告用户,并且魅力下一个调用,这个模块的另一个功能是创建过滤器,用来管理影响应用程序警告信息。

#docs.python.org/lib/warning-filter.html

#有用工具

#pylint:一个非常灵活的元代码分析器

#除了一些质量保证方便试题之外,它还能够检查指定源代码是否遵循某种命名约定,默认设置对应pep8,一个pylint脚本提供了一个shell报告输出

#要安装pylint,可以通过easy_install来使用logiab.installer egg,如下

#图片

#注意,pylint总会在某些情况下给出不好的评级或者抱怨,例如一个被模块本身的代码使用import语句在某些情况下也是很好的(使其在命名空间中可用)

#如果调用采用混合大小写的方法命名程序库,那么它也可能降低评级,在任何情况下,全局评估不像c中的lint那么重要,它只是一个指出潜在改进的工作,

# 调优它第一件要做事情就是,使用-generate-rcfile选项在原始目录下创建一个.pylinrc配置文件,如下

#图片

#在windows下面,~文件夹必须替换成用户文件夹,一般位于documents and settings文件夹中(环境变量)

#配置文件中首先需要修改的是,在reports小节中将reports变量设置为no,以避免生成冗长的报告,在例子中,只需要 用这个工作侦测名称,当完成这个修改之后,这个工具将只会显示警告,如下

#图片

#clonedigger:http://clonedigger.sourceforge.net是一个很好的工具,它尝试访问代码树以侦测代码中相似之处,它基于网站上所说明相当复杂算法,有效地补充了pylint.

#要安装它,可以使用 easy_install,如下

#easy_install CloneDigger

#将得到一个可被用于侦测重复代码的clondigger命令,命令选项可以在http://clonedigger.sourceforge.net/documentation.html上找到

#output.html是它生成的一个html输入,其中包含了clonedigger一个工作报告

时间: 2024-10-28 21:35:20

python高级编程之选择好名称:完2的相关文章

python高级编程之选择好名称:完

由于时间关系,python高级编程不在放在这边进行学习了,如果需要的朋友可以看下面的网盘进行下载 # # -*- coding: utf-8 -*- # # python:2.x # __author__ = 'Administrator' #使用API #跟踪冗长 #创建代码库时,最常见的错误是api冗长(api verbosity),当一个功能对包的调用是一组而不是一个时,出现下面错误 #script_engine包例子 #from script_engine import make_con

python高级编程之选择好名称:pepe8和命名最佳实践

# # -*- coding: utf-8 -*- # # python:2.x # __author__ = 'Administrator' # my_list=['a','b','c','d'] # """ # 大部分标准程序加在构建时都不会忽略可用性,看下面的例子理解下这句话的含义 # """ # if 'e' not in my_list: #     my_list.append('e') # print my_list # #['a'

python高级编程之选择好名称:命名指南

# # -*- coding: utf-8 -*- # # python:2.x # __author__ = 'Administrator' #命名指南 #一组常用的命名规则可以被应用到变量,方法函数和属性上,类和模块的名称在命名空间叫是扮演重要角色的,所以一般有2个模式:觉模式和反模式 #使用has,is前缀命名布尔元素,例如 #当一个元素用来保存布尔值,使用has,is前缀命名布尔元素是一个很好的选择 class DB(object): is_connected=False has_cac

python高级编程之装饰器01

# -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' #装饰器01 #特点是:使得函数和方法封装(接收一个函数并返回增强版本一个函数) #语法:原始场景可以将方法 在定义首部将其定义为类方法或者静态方法,在未使用装饰器之前,语法如下: class WhatFort(object): def it(cls): print 'work with %s:'%cls it=classmethod(it) def uncommo

Python高级编程pdf

下载地址:网盘下载 内容简介  · · · · · · <Python高级编程>通过大量的实例,介绍了Python语言的最佳实践和敏捷开发方法,并涉及整个软件生命周期的高级主题,诸如持续集成.版本控制系统.包的发行和分发.开发模式.文档编写等.<Python高级编程>首先介绍如何设置最优的开发环境,然后以Python敏捷开发方法为线索,阐述如何将已被验证的面向对象原则应用到设计中.这些内容为开发人员和项目管理人员提供了整个软件工程中的许多高级概念以及专家级的建议,其中有些内容的意义

python高级编程之迭代器与生成器

# -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' #迭代器与生成器 #--------------------------------------- #迭代器基于2个方法 """ next:返回容器下一个项目 __iter__:返回迭代器本身 """ #通过内建函数和序列来创建 i=iter('abc') print i.next()#a print i.next(

Python高级编程之生成器(Generator)与coroutine(二):coroutine介绍

原创作品,转载请注明出处:点我 上一篇文章Python高级编程之生成器(Generator)与coroutine(一):Generator中,我们介绍了什么是Generator,以及写了几个使用Generator Function的示例,这一小节,我们会介绍Python的coroutine,以及会有一个小例子,再接下来的文章中会以代码的形式一步步介绍coroutine的高级用法. coroutine(协程) 什么是coroutine?coroutine跟Generator有什么区别?下面先看一段

python高级编程之最佳实践,描述符与属性01

# -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' #最佳实践 """ 为了避免前面所有的问题,必须考虑到几下几点: ~1:应该避免多重继承,可以一些设计模式来代替它 ~2:super使用必须一致,在类层次结构中,应该在所有地方都使用super或者彻底不使用它,滥用super和传统调用是一种滥用方法,建议使用super ~3:不要滥用经典类和新式类,两者都具备代码库将导致不同的mro表现 ~4:调

python高级编程之(类级):子类内建类型

# -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' #类级 #在2.2中,提出了类型(type0与类(class)统一(请访问:https://www.python.org/download/releases/2.2.3/descintro(可能已经不存在了))-这使内建类型的子类化成为可能,并且添加一个新内建类型object #用于所有内建类的公共祖先 #展示一个名为distinctdict类的代码,与平常的dic