框架结构:
get地址:https://github.com/zihui1/selenium3-python3
actionb包中的PageAction主要封装常用的元素操作方式
# encoding = utf-8 from selenium import webdriver from util.ObjectMap import getElement from util.WaitUtil import WaitUtil from util.KeyBoardUtil import KeyboardKeys from util.ClipboardUtil import Clipboard from util.DirAndTime import * from config.VarConfig import ieDriverFilePath,chromeDriverFilePath,firefoxDriverFilePath import time # 定义全局driver变量 driver = None # 全局的等待类实例对象 waitUtil = None def open_browser(browserName,*args): global driver,waitUtil try: if browserName.lower() =="ie": driver = webdriver.Ie(executable_path=ieDriverFilePath) elif browserName.lower() =="chrome": driver = webdriver.Chrome() elif browserName.lower() =="firefox": driver = webdriver.Firefox(executable_path=firefoxDriverFilePath) waitUtil = WaitUtil(driver) except Exception as e: raise e def visit_url(url,*args): # 访问某个网址 global driver try: driver.get(url) except Exception as e: raise e def close_browser(*args): # 关闭浏览器 global driver try: driver.quit() except Exception as e: raise e def sleep(sleepSeconds,*args): # 强制等待 try: time.sleep(int(sleepSeconds)) except Exception as e: raise e def clear(locationType,locatorExpression,*args): # 清楚输入框默认内容 global driver try: getElement(driver,locationType,locatorExpression).clear() except Exception as e: raise e def input_string(locationType,locatorExpression,inputContent): # 在输入框中输入内容 global driver try: if inputContent: getElement(driver,locationType,locatorExpression).send_keys(inputContent) except Exception as e: raise e def refresh(*args): # 刷新当前页面 global driver try: driver.refresh() except Exception as e: raise e def click(LocationType,locatorExpression,*args): # 单击页面元素 global driver try: getElement(driver,LocationType,locatorExpression).click() except Exception as e: raise e def Drop_down_box(assertString = None,*args): # 选择ul类型的下拉框 global driver try: if assertString: getElement(driver,"xpath",'//li[text()="'+assertString+'"]').click() except Exception as e: raise e def assert_string_in_pagesource(assertString,*args): # 断言页面源码是否存在关键字或关键字符串 global driver try: assert assertString in driver.page_source, u'%s :源码中找不到该关键字!'%(assertString) except AssertionError as e: raise AssertionError(e) except Exception as e: raise e def assert_title(titleStr,*args): # 断言页面标题是否存在给定的关键字符串 global driver try: assert titleStr in driver.title, u"%s :title找不到!" %(titleStr) except AssertionError as e: raise AssertionError(e) except Exception as e: raise e def getTitle(*args): # 获取页面标题 global driver try: return driver.title except Exception as e: raise e def getPageSource(*args): # 获取页面源码 global driver try: return driver.page_source except Exception as e: raise e def switch_to_js(locationType,*args): #使用js对页面进行操作 global driver try: return driver.execute_script(locationType) except Exception as e: raise e def switch_to_frame(locationType,frameLocatorExpression,*args): # 切换进入frame global driver try: driver.switch.to.frame(getElement(driver,locationType,frameLocatorExpression)) except Exception as e: print("frame异常") raise e def switch_to_default_content(*args): # 切出frame global driver try: driver.switch_to.default_content() except Exception as e: raise e def paste_string(pasteString,*args): # 模拟键盘复制 try: Clipboard.setText(pasteString) time.sleep(2) KeyboardKeys.twoKeys('ctrl','v') except Exception as e: raise e def press_tab_key(*args): # 模拟键盘tab try: KeyboardKeys.oneKey('tab') except Exception as e: raise e def press_enter_key(*args): # 模拟键盘Enter try: KeyboardKeys.oneKey("enter") except Exception as e: raise e def maximize_browser(): # 窗口最大化 global driver try: driver.maximize_window() except Exception as e: raise e def capture_screen(*args): # 截取屏幕图片 global driver currTime = getCurrentTime() picNameAndPath= str(createCurrentDateDir())+"\"+str(currTime)+".png" try: driver.get_screenshot_as_file(picNameAndPath.replace('\',r'\')) except Exception as e: raise e else: return picNameAndPath def waitPresenceOfElementLocated(locationType,locatorExpression,*args): '''显示等待页面元素出现在Dom中,但并不一定可见,存在则返回该页面元素对象''' global waitUtil try: waitUtil.presenceOfElementLocated(locationType,locatorExpression) except Exception as e: raise e def waitFrameToBeAvailableAndSwitchToIt(locationType,locatorExpression,*args): '''检查frame是否存在,存在则切换进frame控件中''' global waitUtil try: waitUtil.frameToBeAvailaBleSwitchToIt(locationType,locatorExpression) except Exception as e: raise e def waitVisibilityOfElementLocated(locationType,locatorExpression,*args): '''显示等待页面元素出现在DOM中,并且可见,存在返回该页面元素对象''' global waitUtil try: waitUtil.visibilityOfElementLocated(locationType,locatorExpression,*args) except Exception as e: raise e
config包中VarConfig主要放项目路径
# encoding = utf-8 import os # 各浏览器wendriver地址 ieDriverFilePath = "c:\" chromeDriverFilePath = "c:\" firefoxDriverFilePath = "c:\" # 获取当前父级绝对路径 parentDirPath = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) LogPath = parentDirPath+u"\Log\" # 异常截图存放目录绝对路径 screePicturesDir = parentDirPath + u'\exceptionpictures\' # 存放数据文件存放绝对路径 dataFilePath = parentDirPath+u'\testData\登录上海监管平台.xlsx' # 测试数据文件中,测试用例表中部分列对应的数字序号 testCase_testCaseName =2 testCase_frameWorkName = 4 testCase_testStepSheetName =5 testCase_dataSourceSheetName = 6 testCase_isExecute =7 testCase_runTime =8 testCase_testResult = 9 # 用例步骤表中,部分列对应的数字序号 testStep_testStepDescribe = 2 testStep_keyWords = 3 testStep_locationType = 4 testStep_locatorExpression = 5 testStep_operatValue = 6 testStep_runTime = 7 testStep_testResult = 8 testStep_errorInfo = 9 testStep_errorPic = 10 # 数据源表中,是否执行列对应的数字编号 dataSource_isExecute = 13 dataSource_name = 2 dataSource_runTime = 14 dataSource_result = 16
exceptionpictures中主要是放异常截图信息
Log包下放的是Log信息
testData放的是测试用例
testScripts放的是测试脚本
__init__中引入通用的类
#encoding = utf-8 from action.PageAction import * from util.ParseExcel import ParseExcel from config.VarConfig import * from util.Log import Log import time import traceback # 创建解析Excel对象 excelObj = ParseExcel() # 将Excel数据文件加载到内存 excelObj.loadWorkBook(dataFilePath) log = Log()
CreateContacts是数据驱动框架的逻辑
#encoding = utf-8 from . import * from testScripts.WriteTestResult import writeTestResult def dataDriverFun(dataSourceSheetObj,stepSheetObj): try: # 获取数据源表中是否执行列对象 dataIsExecuteColumn = excelObj.getColumn( dataSourceSheetObj,dataSource_isExecute) # 获取数据源表中“姓名”列对象 nameColumn = excelObj.getColumn(dataSourceSheetObj,dataSource_name) # 获取测试步骤表中存在数据区域的行数 stepRowNums = excelObj.getRowsNumber(stepSheetObj) # 记录成功执行的数据条数 successDatas = 0 # 记录被设置为执行的数据条数 requiredDatas = 0 for idx,data in enumerate(dataIsExecuteColumn[1:]): # 遍历数据源表,准备进行数据驱动测试 # 因为第一行是标题行,所以从第二行开始遍历 if data.value == "y": log.info(u'开始添加监管人员%s'%(nameColumn[idx+1].value)) requiredDatas +=1 # 定义记录执行成功步骤数变量 successStep = 0 for index in range(2,stepRowNums+1): # 获取数据驱动测试步骤表中第index行对象 rowObj = excelObj.getRow(stepSheetObj,index) # 获取关键字作为调用的函数名 keyWord = rowObj[testStep_keyWords -1].value # 获取操作元素的定位表达式作为调用函数的参数 locationType = rowObj[testStep_locationType -1].value # 获取操作元素的定位表达式作为调用的函数的参数 locatorExpression = rowObj[testStep_locatorExpression -1].value # 获取操作值作为调用函数的参数 operateValue = rowObj[testStep_operatValue -1].value if isinstance(operateValue,int): operateValue = str(operateValue) if operateValue and operateValue.isalpha(): # 如果operateValue变量不为空,说明有操作值从数据源表中 # 根据坐标获取对应单元格的数据 coordinate = operateValue+str(idx+2) operateValue = excelObj.getCellOfValue(dataSourceSheetObj, coordinate=coordinate) if isinstance(operateValue, int): operateValue = str(operateValue) # 构造需要执行的python表达式,此表达式对应的是PageAction.py文件 # 中的页面动作函数调用的字符串表示 tmpStr = "'%s','%s'"%(locationType.lower(),locatorExpression.replace( "'",'"'))if locationType and locatorExpression else"" if tmpStr: tmpStr+= ",u'"+operateValue+"'" if operateValue else "" else: tmpStr += "u'"+operateValue+"'" if operateValue else "" runStr = keyWord+"("+tmpStr+")" print(runStr) try: eval(runStr) except Exception as e: log.error(u'执行步骤%s发生异常'%rowObj[testStep_testStepDescribe-1].value) log.error(traceback.print_exc()) # # 截取异常屏幕图片 # capturePic = capture_screen() # # 获取详细的异常堆栈信息 # errorInfo = traceback.format_exc() # writeTestResult(stepSheetObj, rowNo=index, # colsNo="caseStep", testResult="faild", # errorInfo=str(errorInfo), picPath=capturePic) else: successStep+=1 log.info(u'执行步骤%s成功'%rowObj[testStep_testStepDescribe-1].value) if stepRowNums == successStep+1: successDatas+=1 # 如果成功执行的步骤数等于步骤表中给出的步骤数 # 说明第idx+2行的数据执行通过,写入通过信息 writeTestResult(dataSourceSheetObj,rowNo=idx+2,colsNo="dataSheet", testResult="pass") else: # 写入失败信息 writeTestResult(dataSourceSheetObj,rowNo=idx+2,colsNo="dataSheet", testResult="faild") else: # 将不需要执行的数据行的执行时间和执行结果单元格清空 writeTestResult(dataSourceSheetObj,rowNo=idx+2,colsNo="dataSheet", testResult="") if requiredDatas == successDatas: # 只要当成功执行的数据条数等于被设置为需要执行的数据条数, # 才表示调用数据驱动的测试用例执行通过 return 1 # 表示调用数据驱动的测试用例执行失败 return None except Exception as e: raise e
WriteTestResult放入写入测试用例的格式和引入位置信息
#encoding = utf-8 from . import * # 用例或用例步骤执行结束后,向Excel中写执行结果信息 def writeTestResult(sheetObj,rowNo,colsNo,testResult, errorInfo = None,picPath = None): # 测试通过结果信息为绿色,失败为红色 colorDict = {"pass":"green","faild":"read","":None} # 因为“测试用例”工作表和“用例不走Sheet表”中都有测试执行时间和测试 # 结果列,定义此字典对象是为了区分具体应该写那个工作表 colsDict = { "testCase":[testCase_runTime,testCase_testResult], "caseStep":[testStep_runTime,testStep_testResult], "dataSheet":[dataSource_runTime,dataSource_result]} try: # 在测试步骤sheet中,写入测试结果 excelObj.writeCell(sheetObj,content=testResult, rowNo=rowNo,colsNo=colsDict[colsNo][1], style=colorDict[testResult]) if testResult == "": # 清空时间单元格内容 excelObj.writeCell(sheetObj,content="", rowNo= rowNo,colsNo= colsDict[colsNo][0]) else: # 在测试步骤sheet中,写入测试时间 excelObj.writeCellCurrentTime(sheetObj,rowNo=rowNo,colsNo=colsDict[colsNo][0]) if errorInfo and picPath: # 在测试步骤sheet中,写入异常信息 excelObj.writeCell(sheetObj,content=errorInfo,rowNo=rowNo, colsNo=testStep_errorInfo) # 在测试步骤sheet中,写入异常截图路径 excelObj.writeCell(sheetObj,content=picPath,rowNo=rowNo,colsNo=testStep_errorPic) else: if colsNo=="caseStep": # 在测试步骤sheet中,清空异常信息单元格 excelObj.writeCell(sheetObj,content="",rowNo=rowNo,colsNo=testStep_errorInfo) excelObj.writeCell(sheetObj,content="",rowNo=rowNo,colsNo=testStep_errorPic) except Exception as e: log.error(u'写excel时发生异常'+traceback.print_exc())
TestShNw放的执行测试步骤
#encoding = utf-8 from . import * from . import CreateContacts from testScripts.WriteTestResult import writeTestResult def TestShNw(): try: # 根据Excel文件中的sheet名获取sheet对象 caseSheet = excelObj.getSheetByName(u'测试用例') # 获取测试用例sheet中是否执行列对象 isExecuteColumn = excelObj.getColumn(caseSheet,testCase_isExecute) # 记录执行成功的测试用例个数 successfulCase = 0 # 记录需要执行的用例个数 requiredCase =0 for idx,i in enumerate(isExecuteColumn[1:]): # 因为用例sheet中第一行为标题行,无须执行 caseName = excelObj.getCellOfValue(caseSheet,rowNo=idx+2, colsNo=testCase_testCaseName) # 循环遍历“测试用例”表中的测试用例,执行被设置为执行的用例 if i.value.lower() == "y": requiredCase +=1 # 获取测试用例表中,第idx+1行中 # 用例执行时所使用的框架类型 useFrameWorkName = excelObj.getCellOfValue( caseSheet,rowNo=idx+2,colsNo=testCase_frameWorkName) # 获取测试用例列中,第idx+1行中执行用例的步骤sheet名 stepSheetName = excelObj.getCellOfValue( caseSheet,rowNo=idx+2,colsNo=testCase_testStepSheetName) log.info('----------'+stepSheetName) if useFrameWorkName == u'数据': log.info(u'***********调用数据驱动************') # 获取测试用例表中,第idx+1行,执行框架为数据驱动的用例所使用的数据sheet名 dataSheetName = excelObj.getCellOfValue( caseSheet,rowNo=idx+2,colsNo=testCase_dataSourceSheetName) # 获取第idx+1行测试用例的步骤sheet对象 stepSheetObj = excelObj.getSheetByName(stepSheetName) # 获取第idx+1行测试用例使用的数据sheet对象 dataSheetObj = excelObj.getSheetByName(dataSheetName) # 通过数据驱动框架执行添加联系人 result = CreateContacts.dataDriverFun(dataSheetObj,stepSheetObj) if result: log.info(u'用例%s执行成功'%(caseName)) successfulCase+=1 writeTestResult(caseSheet,rowNo=idx+2, colsNo="testCase",testResult="pass") else: log.info(u'用例%s执行失败'%(caseName)) writeTestResult(caseSheet,rowNo=idx+2,colsNo="testCase",testResult="faild") elif useFrameWorkName == u"关键字": log.info("*************调用关键字驱动****************") caseStepObj = excelObj.getSheetByName(stepSheetName) stepNums = excelObj.getRowsNumber(caseStepObj) successfulSteps = 0 log.info(u'测试用例工%s步'%(stepNums)) for index in range(2,stepNums+1): # 因为第一行标题行无须执行 # 获取步骤sheet中第index行对象 stepRow = excelObj.getRow(caseStepObj,index) # 获取关键字作为调用的函数名 keyWord = stepRow[testStep_keyWords -1].value # 获取操作元素定位方式作为调用的函数的参数 locationType = stepRow[testStep_locationType -1].value # 获取操作元素的定位表达式作为调用函数的参数 locatorExpression = stepRow[testStep_locatorExpression -1].value # 获取操作值为调用函数的参数 operateValue = stepRow[testStep_operatValue -1].value if isinstance(operateValue,int): # 如果operateValue值为数字型, # 将其转换为字符串,方便字符串拼接 operateValue = str(operateValue) # 构造需要执行的Python表达式,此表达式对应的是PageAction.py文件 # 中的页面动作函数调用的字符串表达式 tmpStr = "'%s','%s'"%(locationType.lower(), locatorExpression.replace("'",'"') )if locationType and locatorExpression else "" if tmpStr: tmpStr+= ",u'"+operateValue+"'" if operateValue else "" else: tmpStr += "u'"+operateValue+"'" if operateValue else "" runStr = keyWord+"("+tmpStr+")" print(runStr) try: # 通过eval函数,将拼接的页面动作函数调用的字符串表示 # 当成有效的Python表达式执行,从而执行测试步骤的sheet # 中关键字在PageAction.py文件中对应的映射方法, # 来完成对页面元素的操作 eval(runStr) except Exception as e: log.info(u"执行步骤%s发生异常"%(stepRow[testStep_testStepDescribe-1].value)) # 截取异常屏幕图片 capturePic = capture_screen() # 获取详细的异常堆栈信息 errorInfo = traceback.format_exc() writeTestResult(caseStepObj,rowNo=index, colsNo="caseStep",testResult="faild", errorInfo=str(errorInfo),picPath=capturePic) else: successfulSteps +=1 log.info(u'执行步骤%s成功'%(stepRow[testStep_testStepDescribe-1].value)) writeTestResult(caseStepObj,rowNo=index,colsNo="caseStep",testResult="pass") if successfulSteps == stepNums -1: successfulCase+=1 log.info(u'用例%s执行通过'%(caseName)) writeTestResult(caseSheet,rowNo=idx+2, colsNo="testCase",testResult="pass") else: log.info(u"用例%s执行失败"%(caseName)) writeTestResult(caseSheet,rowNo=idx+2,colsNo="testCase",testResult="faild") else: # 清空不需要执行用例的执行时间和执行结果, # 异常信息,异常图片单元格 writeTestResult(caseSheet,rowNo=idx+2, colsNo="testCase",testResult="") log.info(u"共%s条用例,%s条需要被执行,成功执行%s条" %(len(isExecuteColumn)-1,requiredCase,successfulCase)) except Exception as e: log.info("出现异常"+traceback.format_exc())
util包为工具类包封装一些工具类
DirAndTime是封装截图位置和时间信息
# encoding = utf-8 import time,os from datetime import datetime from config.VarConfig import screePicturesDir # 获取当前日期 def getCurrentDate(): timeTup = time.localtime() currentDate = str(timeTup.tm_year)+"-"+str(timeTup.tm_mon)+"-"+ str(timeTup.tm_mday) return currentDate # 获取当前时间 def getCurrentTime(): timeStr = datetime.now() nowTime = timeStr.strftime('%H-%M-%S-%f') return nowTime # 创建截图存放目录 def createCurrentDateDir(): dirName = os.path.join(screePicturesDir,getCurrentDate()) if not os.path.exists(dirName): os.makedirs(dirName) return dirName if __name__ == "__main__": print(getCurrentDate()) print(getCurrentTime()) print(createCurrentDateDir())
Log封装Log类
#coding=utf-8 import logging import time from config.VarConfig import * class Log: def __init__(self): self.logname = os.path.join(LogPath, '{0}.log'.format(time.strftime('%Y-%m-%d'))) def __printconsole(self, level, message): # 创建一个logger logger = logging.getLogger() logger.setLevel(logging.DEBUG) # 创建一个handler,用于写入日志文件 fh = logging.FileHandler(self.logname,'a',encoding='utf-8') fh.setLevel(logging.DEBUG) # 再创建一个handler,用于输出到控制台 ch = logging.StreamHandler() ch.setLevel(logging.DEBUG) # 定义handler的输出格式 formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s') fh.setFormatter(formatter) ch.setFormatter(formatter) # 给logger添加handler logger.addHandler(fh) logger.addHandler(ch) # 记录一条日志 if level == 'info': logger.info(message) elif level == 'debug': logger.debug(message) elif level == 'warning': logger.warning(message) elif level == 'error': logger.error(message) logger.removeHandler(ch) logger.removeHandler(fh) # 关闭打开的文件 fh.close() def debug(self,message): self.__printconsole('debug', message) def info(self,message): self.__printconsole('info', message) def warning(self,message): self.__printconsole('warning', message) def error(self,message): self.__printconsole('error', message) if __name__ == "__main__": Log().info("infisdlfjkdsf")
ObjectMap封装选择器类
# encoding = utf-8 from selenium.webdriver.support.ui import WebDriverWait # 获取单个元素 def getElement(driver,locationType,locatorExpression): try: element = WebDriverWait(driver,30).until( lambda x:x.find_element(by=locationType,value=locatorExpression)) return element except Exception as e: raise e # 获取多个相同类型的元素对象已List返回 def getElements(driver,locationType,locatorExpression): try: element = WebDriverWait(driver,30).until( lambda x:x.find_elements(by=locationType,value=locatorExpression)) return element except Exception as e: raise e
ParseExcel封装读写Excel类
# encoding = utf-8 import openpyxl from openpyxl.styles import Border,Side,Font import time class ParseExcel(object): def __init__(self): self.worbook = None self.excelFile = None self.font = Font(color = None)#设置字体颜色 # 颜色对应的RGB值 self.RGBDict = {'read':'FFFF3030','green':'FF008B00'} def loadWorkBook(self,excelPathAndName): # 将Excel文件加载到内存,并获取其workbook对象 try: self.workbook = openpyxl.load_workbook(excelPathAndName) except Exception as e: raise e self.excelFile = excelPathAndName return self.workbook def getSheetByName(self,sheetName): # 根据sheet名获取该sheet对象 try: sheet = self.workbook.get_sheet_by_name(sheetName) return sheet except Exception as e: raise e def getSheetByIndex(self,sheetIndex): # 根据sheet的索引号获取该sheet对象 try: sheetName = self.workbook.get_sheet_names()[sheetIndex] except Exception as e: raise e sheet = self.workbook.get_sheet_by_name(sheetName) return sheet def getRowsNumber(self,sheet): # 获取sheet中有数据区域的结束行号 return sheet.max_row def getColsNumber(self,sheet): # 获取sheet中数据区域的结束列号 return sheet.max_column def getStartRowNumber(self,sheet): # 获取sheet中有数据区域的开始的行号 return sheet.min_row def getStartColNumber(self,sheet): # 获取sheet中有数据区域的开始的列号 return sheet.min_column def getRow(self,sheet,rowNo): # 获取sheet中某一行,返回的是这一行所有的数据内容组成的tuple, # 下标从1开始,sheet.rows[1]表示第一列 try: return list(sheet.rows)[rowNo - 1] except Exception as e: raise e def getColumn(self,sheet,colNo): # 获取sheet中某一列,返回的是这一列所有的数据内容组成tuple, # 下标从1开始,sheet.coulumns[1]表示第一列 try: return list(sheet.columns)[colNo -1] except Exception as e: raise e def getCellOfValue(self,sheet,coordinate = None,rowNo = None,colsNo = None): # 根据单元格所在的位置索引获取该单元格中的值,下表从1开始 # sheet.cell(row =1,column = 1).value,表示Excel中第一行第一列的值 if coordinate != None: try: return sheet[coordinate].value except Exception as e: raise e elif coordinate is None and rowNo is not None and rowNo is not None and colsNo is not None: try: return sheet.cell(row = rowNo,column = colsNo).value except Exception as e: raise e else: raise Exception("Insufficient Coordinates of cell!") def getCellOfObject(self,sheet,coordinate = None,rowNo = None,colsNo = None): # 获取某个单元格的对象,可以根据单元格所在位置的数字索引, # 也可以直接根据Excel中单元格的编码及坐标 # 如getCellObject(sheet,coordinate = 'A1')或 # getCellObject(sheet,rowNo = 1,colsNo = 2) if coordinate != None: try: return sheet.cell(coordinate = coordinate) except Exception as e: raise e elif coordinate == None and rowNo is not None and colsNo is not None: try: return sheet.cell(row = rowNo,column = colsNo) except Exception as e: raise e else: raise Exception("Insufficient Coordinates of cell!") def writeCell(self,sheet,content,coordinate = None,rowNo = None,colsNo = None,style = None): # 根据单元格在Excel中的编码坐标或者数字索引坐标向单元格中写入数据, # 下表从1开始,参数style表示字体的颜色的名字,比如red,green if coordinate is not None: try: sheet.cell(coordinate = coordinate).value = content if style is not None: sheet.cell(coordinate = coordinate). font = Font(color= self.RGBDict[style]) self.workbook.save(self.excelFile) except Exception as e: raise e elif coordinate == None and rowNo is not None and colsNo is not None: try: sheet.cell(row = rowNo,column = colsNo).value = content if style: sheet.cell(row = rowNo,column = colsNo). font = Font(color=self.RGBDict[style]) self.workbook.save(self.excelFile) except Exception as e: raise e else: raise Exception("Insufficient Coordinates of cell!") def writeCellCurrentTime(self,sheet,coordinate = None,rowNo = None,colsNo = None): # 写入当前的时间,下表从1开始 now = int(time.time())#显示为时间戳 timeArray = time.localtime(now) currentTime = time.strftime("%Y-%m-%d %H:%M:%S",timeArray) if coordinate is not None: try: sheet.cell(coordinate = coordinate).value = currentTime self.workbook.save(self.excelFile) except Exception as e: raise e elif coordinate == None and rowNo is not None and colsNo is not None: try: sheet.cell(row = rowNo,column = colsNo).value = currentTime self.workbook.save(self.excelFile) except Exception as e: raise e else: raise Exception("Insufficient Coordinates of cell!") if __name__ == "__main__": from config.VarConfig import * pe = ParseExcel() pe.loadWorkBook(dataFilePath) print('通过名称获取sheet对象的名称:',pe.getSheetByName(u'联系人').title) print('通过索引号获取sheet对象的名称:',pe.getSheetByIndex(0).title) sheet = pe.getSheetByIndex(0) print(type(sheet)) print('获取最大行',pe.getRowsNumber(sheet))#获取最大行 print('获取最大列',pe.getColsNumber(sheet))#获取最大列 rows = pe.getRow(sheet,1)#获取第一行 print(rows().value) for i in rows: print(i.value) print(pe.getCellOfValue(sheet,rowNo=1,colsNo=1)) # pe.writeCell(sheet,u'我爱祖国',rowNo=10,colsNo=10) # pe.writeCellCurrentTime(sheet,rowNo=10,colsNo=11)
WaitUtil封装显示等待元素
# encoding = utf-8 from selenium.webdriver.support.ui import WebDriverWait from selenium.webdriver.common.by import By from selenium.webdriver.support import expected_conditions as EC import time class WaitUtil(object): def __init__(self,driver): self.locationTypeDict = { "xpath":By.XPATH, "id":By.ID, "name":By.NAME, "class_name":By.CLASS_NAME, "tag_name":By.TAG_NAME, "like_text":By.LINK_TEXT, "partial_link_text":By.PARTIAL_LINK_TEXT } self.driver = driver self.wait = WebDriverWait(self.driver,30) def presenceOfElementLocated(self,locationType,locatorExpression,*args): '''显示等待页面元素出现在Dom中,但并不一定可见,存在则返回该页面元素对象''' try: if locationType.lower() in self.locationTypeDict: element = self.wait.until(EC.presence_of_element_located((self.locationTypeDict[ locationType.lower()],locatorExpression))) return element else: raise TypeError(u"未找到定位方式,请确认定位方法是否写正确") except Exception as e: raise e def frameToBeAvailaBleSwitchToIt(self,locationType,locatorExpression,*args): ''' 检查Frame是否存在,存在则切换斤Frame控件中 ''' try: self.wait.until(EC.frame_to_be_available_and_switch_to_it((self.locationTypeDict[ locationType.lower()],locatorExpression))) except Exception as e: raise e def visibilityOfElementLocated(self,locationType,locatorExpression,*args): '''显示等待页面元素出现''' try: element = self.wait.until(EC.visibility_of_element_located(( self.locationTypeDict[locationType.lower()],locatorExpression))) return element except Exception as e: raise e if __name__ == "__main__": from selenium import webdriver driver = webdriver.Chrome() driver.get("http://mail.163.com") wu = WaitUtil(driver) wu.frameToBeAvailaBleSwitchToIt("xpath","//iframe[starts-with(@id, 'x-URS-iframe')]") ps = wu.visibilityOfElementLocated("name","email") wc = wu.presenceOfElementLocated("name","email") # wc = WebDriverWait(driver, 30).until(EC.presence_of_element_located((By.NAME, 'email'))) wc.send_keys("1111") ps.send_keys("11111") time.sleep(5) driver.quit()