python函数封装 python函数封装成模块

python中封装的优缺点1 封装概述
封装(Encapsulation) , 指的是在设计类时,将不需要对外提供的内容都隐藏起来,提供公共方法以供外部对其访问 。
具体指的是刻意地将一些属性和方法隐藏(私有化)在类的内部,这样在使用此类时,将无法直接以类对象.属性名、或 类对象.方法名(参数) 的形式调用这些私有属性或私有方法,而只能用未隐藏的公有方法间接操作这些隐藏的私有属性和私有方法 。
封装的优点 , 如下所示:
封装保证了类内部数据结构的完整性:封装之后 , 用户无法直接看到类中的数据结构,只能使用类允许公开的数据(通常指公有方法),很好地避免了外部对内部数据的影响,提高了程序的可维护性 。
封装数据可以很好的保护隐私 。
封装方法的主要原因是隔离复杂度 。
封装提高了代码的复用性 。
还可以轻松实现避免用户对类中属性和方法的不合理操作:用户只能借助暴露出来的类方法来访问数据,我们只需要在这些暴露的方法中加入适当的控制逻辑,即可轻松实现用户对类中属性或方法的不合理操作 。
2 Python 类的简单封装
为了实现 Python 类的封装,Python 采取了下面的方法:
公有(共有):默认情况下 , 类中的变量和方法都是公有的,它们的名称前都没有下划线,公有的变量和方法,在类的外部、类内部以及子类中,都可以正常访问 。
私有:类中的变量或方法以双下划线 __ 开头命名,则该变量或方法为私有的,私有的变量或方法,只能在本类内部使用,类的外部以及子类都无法使用 。
也有把变量名或方法名以单下划线 _ 开头定义的 , 通常也表示私有的 。
使用python简单封装selenium常用函数 年前走查脚本代码时,发现大家对selenium功能都在重复造轮子,而且容易出现一些常见低级bug 。于是在闲暇之余,封装一些常用的selenium功能 。
在某些网页中 , 存在多个frame嵌套 。而selenium提供的find_element函数只能在当前frame中查找 , 不能切换到其他frame中,需要从最上级frame中逐步切换(当然也可以指定xpath的绝对路径,但是一般没人这么做) 。在我们写代码过程中 , 需要明确知道当前frame位置和需要寻找元素的frame位置 。在frame切换过程中 , 容易因为疏忽导致frame切换错误导致元素无法找到的bug 。
页面中分布的frame,可以理解为树状结构 。因此我们可以采用递归的方式 ,  沿着某条搜索路线frame节点 , 依次对树中每个节点均做一次访问 。
我们以163网址上的登录框为例:点击登录按钮,弹出登录iframe页面 。输入框位置在iframe中,因此我们不能使用xpath获取元素位置,需要进入iframe中 , 然后获取元素 。
手动切换ifame可能会产生bug,因此需要一套自动切换和检索frame的机制 。具体代码如下:
需要注意的是:如果页面中多个frame中,存在相同的xpath元素 。还是需要指定frame的路径,否则会返回搜索到的第一个元素 。
强制等待
直接调用系统time.sleep函数,不管页面加载情况一定会等待指定的时间,即使元素已被加载。
1.如果设置的时间较长 , 会浪费时间
2.如果设置的时间较短 , 元素可能没有加载 。
页面中某元素如果未能立即加载 , 隐式等待告诉WebDriver需等待一定的时间,然后去查找元素 。默认不等待,隐式等待作用于整个WebDriver周期,只需设置一次即可 。
1.在上文的find_element函数中,采用递归方式在所有frame寻找元素 。若采用隐式等待,则在每个frame中都需要等待设定的时间,耗时非常长 。

推荐阅读