selenium+python 怎么捕获异常继续脚本?
本帖最后由 maqi5630 于 2017-2-16 16:20 编辑问题起因:我利用python+selenium写了个脚本在企业微信后台往某个标签中人员名单,这些人员名单事先已经有人把添加到组织架构中,但是可能是由于人工添加的导致由几个人没有添加进去。
所以我在这里利用CSV读取人员名单信息添加到标签中的时候,由于有几个人没有事先添加到组织架构中,所以读到这个人员的时候程序就报错了,
求助信息:
我现在就是想问下,怎么在脚本中添加即使脚本报错了也继续执行脚本?同时最好能够把读取csv文件中那个在系统组织架构没有人员信息也打印出来!
我知道应该是用捕获异常弄,但是由于我是自学的python selenium,所以不怎么会写,哪位大神帮忙看下怎么写?
代码截图
主要在for 循环那里会出错。
报错信息
关注我也想知道怎么捕获异常 下面的语句估计能满足你的需求,
不过建议用在合适的地方,如脚本执行不稳定的地方,
平常的地方就让它报错呗,报错必然是和预期不符合了,这时就需要对错误进行分析,而不是一味想着让脚本执行下去。
个人意见仅供参考:
try:
正常的操作
......................
except:
发生异常,执行这块代码
......................
else:
如果没有异常执行这块代码 若尘_51 发表于 2017-2-17 10:48
下面的语句估计能满足你的需求,
不过建议用在合适的地方,如脚本执行不稳定的地方,
平常的地方就让它报 ...
谢谢,已经解决了,感谢 梦想家 发表于 2017-2-16 16:42
关注我也想知道怎么捕获异常
我已经解决了,代码见楼下 # coding=utf-8
from selenium import webdriver
import time
import csv
driver = webdriver.Firefox()
driver.maximize_window()
driver.get("https://qy.weixin.qq.com")
time.sleep(20)
driver.find_element_by_xpath(".//*[@id='menu_contacts']/a").click()
time.sleep(3)
driver.find_element_by_css_selector(".contact_tab_right").click()
# 选择标签名
driver.find_element_by_xpath(".//*[@id='contact-tag']/div/div/div/ul/li/a/span").click()
time.sleep(3)
# 应用标签添加成员脚本
driver.find_element_by_css_selector(".memberList_header_link.js_tag_member").click()
time.sleep(3)
# 读取本地csv文件
my_file = "D:\\datainfo.csv"
data = csv.reader(open(my_file, "r"))
# 循环输出每一行信息
for phone in data:
try:
driver.find_element_by_xpath(".//*[@id='token-input-']").send_keys(phone)
time.sleep(2)
driver.find_element_by_xpath(".//*[@id='token-input-dropdown-result']/ul/li").click()
time.sleep(2)
except Exception as e:
# 清除没有人员手机
driver.find_element_by_xpath(".//*[@id='token-input-']").clear()
# 打印没有人员信息
print(phone, phone)
continue
# coding=utf-8
# 店长应用添加人员
from selenium import webdriver
import time
import csv
driver = webdriver.Firefox()
driver.maximize_window()
driver.get("https://qy.weixin.qq.com")
time.sleep(20)
driver.find_element_by_xpath(".//*[@id='menu_contacts']/a").click()
time.sleep(3)
driver.find_element_by_css_selector(".contact_tab_right").click()
# 选择标签名
driver.find_element_by_xpath(".//*[@id='contact-tag']/div/div/div/ul/li/a/span").click()
time.sleep(3)
# 店长应用标签添加成员脚本
driver.find_element_by_css_selector(".memberList_header_link.js_tag_member").click()
time.sleep(3)
# 读取本地csv文件
my_file = "D:\\datainfo.csv"
data = csv.reader(open(my_file, "r"))
# 循环输出每一行信息
for phone in data:
try:
driver.find_element_by_xpath(".//*[@id='token-input-']").send_keys(phone)
time.sleep(2)
driver.find_element_by_xpath(".//*[@id='token-input-dropdown-result']/ul/li").click()
time.sleep(2)
except Exception as e:
# 清除没有人员手机
driver.find_element_by_xpath(".//*[@id='token-input-']").clear()
# 打印没有人员信息
print(phone, phone)
continue
# coding=utf-8
# 店长应用添加人员
from selenium import webdriver
import time
import csv
driver = webdriver.Firefox()
driver.maximize_window()
driver.get("https://qy.weixin.qq.com")
time.sleep(20)
driver.find_element_by_xpath(".//*[@id='menu_contacts']/a").click()
time.sleep(3)
driver.find_element_by_css_selector(".contact_tab_right").click()
# 选择标签名
driver.find_element_by_xpath(".//*[@id='contact-tag']/div/div/div/ul/li/a/span").click()
time.sleep(3)
# 店长应用标签添加成员脚本
driver.find_element_by_css_selector(".memberList_header_link.js_tag_member").click()
time.sleep(3)
# 读取本地csv文件
my_file = "D:\\datainfo.csv"
data = csv.reader(open(my_file, "r"))
# 循环输出每一行信息
for phone in data:
try:
driver.find_element_by_xpath(".//*[@id='token-input-']").send_keys(phone)
time.sleep(2)
driver.find_element_by_xpath(".//*[@id='token-input-dropdown-result']/ul/li").click()
time.sleep(2)
except Exception as e:
# 清除没有人员手机
driver.find_element_by_xpath(".//*[@id='token-input-']").clear()
# 打印没有人员信息
print(phone, phone)
continue
maqi5630 发表于 2017-2-17 14:22
我已经解决了,代码见楼下
好的 嘿嘿 :lol
try应该如果正确应该是执行的,不正确就不执行,然后去except:下执行对吧?
ActionChains(driver).move_to_element(center).perform()
#book =xlwt.Workbook(encoding='utf-8')
#sheet = book.add_sheet('test_sheet',cell_overwrite_ok=True)
#i=0
try:#检测登录是否成功
driver.find_element_by_xpath('//a[@class="loginOut"]').click()
print('账号:%s密码:%s登录成功'%(username,password))
#sheet.write(0,i+1,'登录成功')
except:
print('账号:%s密码:%s登录失败'%(username,password))
#sheet.write(0,i+1,'登录失败')
time.sleep(2)
try:#检测退出账号是否成功
driver.find_element_by_link_text('登录').click()
print('退出账号成功')
except:
print('退出账号失败')
#book.save("E:\\test1.xls")
页:
[1]