[BUG]自己的bug自己解,记一次在变量使用过程引发的bug

【实现的功能要求】在短信编辑界面,将所有的emoji表情全部插入到编辑区域,其中表情共有5页,每遍历完一页时需要自动翻页重新获取表情并插入,在第5页中只有10个表情

下面先看看这段代码,大家能否看出有什么问题?

 1 #-*- coding:utf-8 -*-
 2 '''
 3 Created on 2018年7月30日
 4 
 5 @author: anyd
 6 '''
 7 from uiautomator import device as d
 8 
 9 radiobutton = d(className = 'android.widget.RadioButton').count # 获取所有表情的页数
10 emoji_number = d(resourceId ='com.android.mms:id/iv_emoticon_icon').count # 获取每页表情的数量
11 for i in range(radiobutton):
12     for j in range(emoji_number):
13         #将每页的表情一个一个的插入到编辑区域
14         d(resourceId = 'com.android.mms:id/iv_emoticon_icon',instance = j).click()
15     i += 1
16     #如果表情未到最后一页时,需要翻页
17     if i < radiobutton:
18         d(resourceId = 'com.android.mms:id/iv_emoticon_icon').swipe.left(steps=5)
19     #表情到最后一页了,提示完成
20     else:
21         print 'done'

上面这段代码再执行到添加第5页的表情时会报错,通过再第11行和12行之间添加 print emoji_numer时,发现每页的表情数量都是21个,但实际情况是在第5页时只有10个表情,代码运行与实际的不符,明显是哪里有问题,我们再看看这个获取表情数量是在哪里就开始定义了,在最前面读到第1页的表情数量就被赋值进去了,所以导致第12行的 for 循环时它只会用前面已定义好的变量值,我们要实现的是再每一页时要去重新读取表情数量(因为每一页的表情数量不统一),然后重新赋值进变量中供后面使用,修改代码如下,将第10行的获取表情数量代码移到第11行和12行之间,修改如下:

 1 #-*- coding:utf-8 -*-
 2 '''
 3 Created on 2018年7月30日
 4 
 5 @author: anyd
 6 '''
 7 from uiautomator import device as d
 8 
 9 radiobutton = d(className = 'android.widget.RadioButton').count # 获取所有表情的页数
10 for i in range(radiobutton):
11     emoji_number = d(resourceId ='com.android.mms:id/iv_emoticon_icon').count # 获取每页表情的数量
12     for j in range(emoji_number):
13         #将每页的表情一个一个的插入到编辑区域
14         d(resourceId = 'com.android.mms:id/iv_emoticon_icon',instance = j).click()
15     i += 1
16     #如果表情未到最后一页时,需要翻页
17     if i < radiobutton:
18         d(resourceId = 'com.android.mms:id/iv_emoticon_icon').swipe.left(steps=5)
19     #表情到最后一页了,提示完成
20     else:
21         print 'done'

再次运行后,表现正常,与预期相符。

 

总结:如果在程序中使用到的变量对应的赋值不是唯一(可变),那一定不能在程序最前面就定义,否则后面的坑还是得自己去填,涉及到的赋值可变时,在对应的变量中随用随赋(在需要使用时再去重新赋值,如上面的例子)

posted @ 2018-07-30 18:00  iSZ  阅读(253)  评论(0编辑  收藏  举报