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中都需要等待设定的时间,耗时非常长 。
2.某些页面我们想要的元素已经加载完毕,但是部分其他资源未加载 。隐式等待必须等待所有元素加载完毕 , 增加额外等待时间 。
显示等待一般作用于某一个元素,在设定的时间范围内,默认每间隔0.5秒查找元素 。返回被加载的元素,若超过设定的时间范围未能查找则报错 。显示等待作为selenium常用的等待机制,我们来看下他的源码和机制 。
driver 注释中解释为WebDriver实例,但是代码中并未有相关检测 , 因此可以传入任何对象
但是__repr__函数中使用到session_id属性,如果需要显示属性或者转为str对象,最好在driver对象中添加session_id属性
在until函数中 , 我们可以看到driver对象传入method函数 。在计时结束前,在不断循环执行method函数,如果method函数有正常返回值则退出循环,否则报TimeoutException错误 。
可以采用装饰器对隐式等待进行封装,这样代码更加精简
同样的,采用装饰器对其他常用的函数进行封装,例如强制等待、点击、输入文本等 。
装饰器虽然很方便,但也会产生一些麻烦 。例如在find_element函数递归调用过程中,理应只要执行一次装饰器函数 。但因为装饰器已经装饰完毕,导致每次递归都会执行 。例如强制等待的sleep函数 , 如果递归次数越多等待时间越长 。
解除装饰器一般有两种做法:一是约定参数,当递归第二次调用时则不生效 。例如
这种方式实现简单,容易理解 。但是增加了参数限制,在fun函数中就不能使用first_sleep参数 。
二是采用装饰器采用wrapped实现,通过访问wrapped属性获得原始函数 。例如
但是某一个函数被多个装饰器装饰时,需要递归解除装饰器 。例如
最后整体代码如下
这次的封装其实还存在很多问题
1.find_element函数不仅仅只是提供查找元素功能,还提供一些其他功能 , 因此叫element_operation更为合适 。
2.find_element函数的参数过多,并且很多参数的使用并不在函数本身中,对代码阅读很不友好 。
3.得小心避免参数重复问题,假设装饰器sleep和装饰器wait_time都使用time这个参数,将无法区分具体是哪个函数使用 。
4.不利于扩展和维护,当功能过多时find_element的参数过于庞大 。
如果只是简单地封装和使用,上面这种方式也能达到较好的效果 。如果想进一步封装,建议采用链式调用方式,装饰器辅助封装 。例如
这样函数的扩展性和可阅读性有较大的提升
python内置函数python内置函数是什么python页面函数?一起来看下吧:
python内置函数有:
abs:求数值python页面函数的绝对值
abs(-2)2
pmod:返回两个数值python页面函数的商和余数
pmod(5,2)(2,1)pmod(5.5,2)(2.0,1.5)
bool:根据传入的参数的逻辑值创建一个布尔值
bool() #未传入参数Falsebool(0) #数值0、空序列等值为FalseFalsebool(1)True
all:判断可迭代对象的每个元素是否都为True值
all([1,2]) #列表中每个元素逻辑值均为True,返回TrueTrueall(()) #空元组Trueall({}) #空字典True
help:返回对象的帮助信息
help(str)Help on class str in module builtins:class str(object)|str(object='') - str|str(bytes_or_buffer[, encoding[, errors]]) - str||Create a new string object from the given object. If encoding or|errors is specified, then the object must expose a data buffer|that will be decoded using the given encoding and error handler.|Otherwise, returns the result of object.__str__() (if defined)|or repr(object).|encoding defaults to sys.getdefaultencoding().|errors defaults to 'strict'.||Methods defined here:||__add__(self, value, /)Return self value.
_import_:动态导入模块
index = __import__('index')index.sayHello()
locals:返回当前作用域内的局部变量和其值组成的字典
def f():print('before define a ')print(locals()) #作用域内无变量a = 1print('after define a')print(locals()) #作用域内有一个a变量python页面函数,值为1f f()before define a{}after define a{'a': 1}
input:读取用户输入值
s = input('please input your name:')please input your name:Ains'Ain'
open:使用指定的模式和编码打开文件,返回文件读写对象
# t为文本读写,b为二进制读写a = open('test.txt','rt')a.read()'some text'a.close()
eval:执行动态表达式求值
eval('1 2 3 4')10
除python页面函数了上述举例的函数之外,内置函数按分类还可分为:
1、数学运算(7个)
2、类型转换(24个)
3、序列操作(8个)
4、对象操作(7个)
5、反射操作(8个)
6、变量操作(2个)
7、交互操作(2个)
8、文件操作(1个)
9、编译操作(4个)
10、装饰器(3个)
python常用函数1、complex()
返回一个形如 a bj 的复数,传入参数分为三种情况:
参数为空时,返回0j;参数为字符串时 , 将字符串表达式解释为复数形式并返回;参数为两个整数(a,b)时,返回 a bj;参数只有一个整数 a 时,虚部 b 默认为0,函数返回 a 0j 。
2、dir()
不提供参数时,返回当前本地范围内的名称列表;提供一个参数时,返回该对象包含的全部属性 。
3、divmod(a,b)
a -- 代表被除数,整数或浮点数;b -- 代表除数,整数或浮点数;根据 除法运算 计算 a,b 之间的商和余数 , 函数返回一个元组(p,q) ,p 代表商 a//b ,q 代表余数 a%b 。
4、enumerate(iterable,start=0)
iterable -- 一个可迭代对象 , 列表、元组序列等;start -- 计数索引值,默认初始为0‘该函数返回枚举对象是个迭代器,利用 next() 方法依次返回元素值 , 每个元素以元组形式存在,包含一个计数元素(起始为 start )和 iterable 中对应的元素值 。
如何利用Python自动完成对网页平台上可点击的元素操作,用什么模块 , 具体函数有哪些 , 请大神指教用selenium就可以python页面函数了python页面函数,它模拟打开浏览器,打开网页 。
通过页面元素的特征,定位到要点击的元素,click()方法就可以完成点击
比如
self.driver.find_element_by_xpath('//ul[@class="uhomeTagList-ul"]/li[2]').click()
【python页面函数 python怎么写页面】python页面函数的介绍就聊到这里吧,感谢你花时间阅读本站内容 , 更多关于python怎么写页面、python页面函数的信息别忘了在本站进行查找喔 。

    推荐阅读