[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'
再次运行后,表现正常,与预期相符。
总结:如果在程序中使用到的变量对应的赋值不是唯一(可变),那一定不能在程序最前面就定义,否则后面的坑还是得自己去填,涉及到的赋值可变时,在对应的变量中随用随赋(在需要使用时再去重新赋值,如上面的例子)