感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的:
① 2000多本Python电子书(主流和经典的书籍应该都有了)
② Python标准库资料(最全中文版)
③ 项目源码(四五十个有趣且经典的练手项目及源码)
④ Python基础入门、爬虫、web开发、大数据分析方面的视频(适合小白学习)
⑤ Python学习路线图(告别不入流的学习)
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
#encoding=utf-8
from openpyxl import load_workbook
class ParseExcel(object):
def init(self, excelPath, sheetName):
# 将要读取的excel加载到内存
self.wb = load_workbook(excelPath)
# 通过工作表名称获取一个工作表对象
self.sheet = self.wb.get_sheet_by_name(sheetName)
# 获取工作表中存在数据的区域的最大行号
self.maxRowNum = self.sheet.max_row
def getDatasFromSheet(self):
# 用于存放从工作表中读取出来的数据
dataList = []
# 因为工作表中的第一行是标题行,所以需要去掉
for line in self.sheet.rows:
# 遍历工作表中数据区域的每一行,
# 并将每行中各个单元格的数据取出存于列表tmpList中,
# 然后再将存放一行数据的列表添加到最终数据列表dataList中
tmpList = []
tmpList.append(line[1].value)
tmpList.append(line[2].value)
dataList.append(tmpList)
# 将获取工作表中的所有数据的迭代对象返回
return dataList[1:]
if name == ‘main’:
excelPath = u’E:\数据驱动\测试数据.xlsx’
sheetName = u"搜索数据表"
pe = ParseExcel(excelPath, sheetName)
print pe.getDatasFromSheet()
for i in pe.getDatasFromSheet():
print i[0], i[1]
**加print调试日志:**
#encoding=utf-8
from openpyxl import load_workbook
class ParseExcel(object):
def init(self,excelPath,sheetName):
self.wb=load_workbook(excelPath)
self.sheet=self.wb.get_sheet_by_name(sheetName)
self.maxRowNum=self.sheet.max_row
def getDatasFromSheet(self):
dataList=[]
for line in self.sheet.rows:
tmpList=[]
tmpList.append(line[1].value)
print “line[1].value”,line[1].value
tmpList.append(line[2].value)
print “line[2].value”,line[2].value
dataList.append(tmpList)
print dataList[1:]
return dataList[1:]
if name==‘main’:
excelPath=u"d:\test\0627\测试数据.xlsx"
sheetName=u"搜索数据表"
pe=ParseExcel(excelPath,sheetName)
print pe.getDatasFromSheet()
for i in pe.getDatasFromSheet():
print i[0],i[1]
单独运行结果:
D:\test\0627>python ExcelUtil.py
ExcelUtil.py:7: DeprecationWarning: Call to deprecated function get_sheet_by_name (Use wb[sheetname]).
self.sheet=self.wb.get_sheet_by_name(sheetName)
line[1].value 搜索词
line[2].value 期望结果
line[1].value 邓肯
line[2].value 蒂姆
line[1].value 乔丹
line[2].value 迈克尔
line[1].value 库里
line[2].value 斯蒂芬
[[u’\u9093\u80af’, u’\u8482\u59c6’], [u’\u4e54\u4e39’, u’\u8fc8\u514b\u5c14’], [u’\u5e93\u91cc’, u’\u65af\u8482\u82ac’]]
[[u’\u9093\u80af’, u’\u8482\u59c6’], [u’\u4e54\u4e39’, u’\u8fc8\u514b\u5c14’], [u’\u5e93\u91cc’, u’\u65af\u8482\u82ac’]]
line[1].value 搜索词
line[2].value 期望结果
line[1].value 邓肯
line[2].value 蒂姆
line[1].value 乔丹
line[2].value 迈克尔
line[1].value 库里
line[2].value 斯蒂芬
[[u’\u9093\u80af’, u’\u8482\u59c6’], [u’\u4e54\u4e39’, u’\u8fc8\u514b\u5c14’], [u’\u5e93\u91cc’, u’\u65af\u8482\u82ac’]]
邓肯 蒂姆
乔丹 迈克尔
库里 斯蒂芬
**最后运行的脚本:**
data_drivern_by_excel.py:
#encoding=utf-8
from selenium import webdriver
import unittest,time
import logging,traceback
import ddt
from ExcelUtil import ParseExcel
from selenium.common.exceptions import NoSuchElementException
#初始化日志对象
logging.basicConfig(
#日志级别
level=logging.INFO,
#日志格式
#时间、代码所在文件名、代码行号、日志级别名称、日志信息
format=‘%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s’,
#打印日志的时间
datefmt=‘%a,%Y-%m-%d %H:%M:S’,
#日志文件存放的目录(目录必须存在)及日志文件名
filename=‘d:\test\0627\report.log’,
#打开日志文件的方式
filemode=‘w’
)
excelPath=u"d:\test\0627\测试数据.xlsx"
sheetName=u"搜索数据表"
#创建ParseExcel类的实例对象
excel=ParseExcel(excelPath,sheetName)
#数据驱动装饰器
@ddt.ddt
class TestDemo(unittest.TestCase):
def setUp(self):
self.driver=webdriver.Firefox(executable_path=‘c:\geckodriver’)
@ddt.data(*excel.getDatasFromSheet())#对调用函数返回的含列表的列表进行解包,传过来的就是列表中的一个列表
def test_dataDrivenByFile(self,data):
print “tuple(data):”,tuple(data)#把传过来的一个列表转换成元祖,包含两个元素,搜索值和期望值
testData,expectData=tuple(data)
print “testData:”,testData#调试用
print “expectData:”,expectData#调试用
url=‘http://www.baidu.com’
#访问百度首页
self.driver.get(url)
#讲浏览器窗口最大化
self.driver.maximize_window()
#print testData,expectData
#设置隐式等待时间为10秒钟
self.driver.implicitly_wait(10)
try:
#获取当前的时间戳,用于后面计算查询耗时用
start=time.time()
#获取当前时间的字符串,表示测试开始时间
startTime=time.strftime(“%Y-%m-%d %H:%M:%S”,time.localtime())
#找到搜索输入框,并输入测试数据
self.driver.find_element_by_id(‘kw’).send_keys(testData)
#找到搜索按钮,并点击
self.driver.find_element_by_id(‘su’).click()
time.sleep(3)
#断言期望结果是否出现在页面源代码中
self.assertTrue(expectData in self.driver.page_source)
print u"搜索-%s,期望-%s"%(testData,expectData)
except NoSuchElementException,e:
logging.error(u"查找的页面元素不存在,异常堆栈信息:“+str(traceback.format_exc()))
except AssertionError,e:
logging.info(u’搜索-”%s",期望-“%s”,-失败’%(testData,expectData))
except Exception,e:
logging.error(u"未知错误,错误信息:“+str(traceback.format_exc()))
else:
logging.info(u’搜索- “%s”,期望-”%s"-通过’%(testData,expectData))
def tearDown(self):
self.driver.quit()
如果你也是看准了Python,想自学Python,在这里为大家准备了丰厚的免费学习大礼包,带大家一起学习,给大家剖析Python兼职、就业行情前景的这些事儿。
一、Python所有方向的学习路线
Python所有方向路线就是把Python常用的技术点做整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照上面的知识点去找对应的学习资源,保证自己学得较为全面。
二、学习软件
工欲善其必先利其器。学习Python常用的开发软件都在这里了,给大家节省了很多时间。
三、全套PDF电子书
书籍的好处就在于权威和体系健全,刚开始学习的时候你可以只看视频或者听某个人讲课,但等你学完之后,你觉得你掌握了,这时候建议还是得去看一下书籍,看权威技术书籍也是每个程序员必经之路。
四、入门学习视频
我们在看视频学习的时候,不能光动眼动脑不动手,比较科学的学习方法是在理解之后运用它们,这时候练手项目就很适合了。
四、实战案例
光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。
五、面试资料
我们学习Python必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作。
成为一个Python程序员专家或许需要花费数年时间,但是打下坚实的基础只要几周就可以,如果你按照我提供的学习路线以及资料有意识地去实践,你就有很大可能成功!
最后祝你好运!!!
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!