Python 读写excel类
#-*- coding: utf8 -*- import xlrd import xlwt from Public import GlobalClass def openexcel(path): try: data = xlrd.open_workbook(path) return data except Exception as e: print (e) #将测试结果写入一个Excel,传:保存路径,sheet名称,读取Excel时保存的Keys,要写入Excel的数据,行数,列数 def writeexcel(path,sheetname,keys,values,nrows,ncols): Path = path wb=xlwt.Workbook() sheet=wb.add_sheet(sheetname) Keys = keys value = values Len = len(value) rows = nrows cols = ncols for k in range(0,cols): sheet.write(0,k,Keys[k]) for i in range(0,Len): #由于第1行已经写入了表头,所以要从第2行开始写数据 for j in range(1,rows): data = value[i] for l in range(0,cols): sheet.write(j,l,str(data[Keys[l]])) wb.save(Path) #将测试结果写入一个Excel(传入数组),传:保存路径,sheet名称,读取Excel时保存的Keys,执行统计时保存的SKeys,要写入Excel的数据,行数,列数 def writeexcellist(path,sheetnamelist,keys,skeys,valueslist,nrowslist,ncolslist): Path = path wb=xlwt.Workbook() # print(sheetnamelist) for s in range(len(sheetnamelist)): sheet=wb.add_sheet(sheetnamelist[s]) Keys = keys Skeys = skeys value = valueslist[s] rows = nrowslist[s] cols = ncolslist[s] if sheetnamelist[s] == "Result": for k in range(0,cols): sheet.write(0,k,Skeys[k]) for r in range(1,rows): #由于第1行已经写入了表头,所以要从第2行开始写数据 for c in range(0,cols): sheet.write(r,c,str(value[r-1][Skeys[c]])) else: for k in range(0,cols): sheet.write(0,k,Keys[k]) for r in range(1,rows): #由于第1行已经写入了表头,所以要从第2行开始写数据 for c in range(0,cols): sheet.write(r,c,str(value[r-1][Keys[c]])) wb.save(Path) #获取sheet总行和总列 def GetRowAndCol(path,sheetname): try: data = openexcel(path) table = data.sheet_by_name(sheetname) nrows = table.nrows #行数 ncols = table.ncols #列数 list =[nrows,ncols] except: list = False # list = (nrows,ncols) # print(list) return list #根据用例状态获取sheet总行和总列 def GetRowByState(path,sheetname): data = openexcel(path) # print(sheetname) table = data.sheet_by_name(sheetname) nrows = table.nrows #行数 ncols = table.ncols #列数 srows = 1 #行数 # scols = 1 #列数 # list =[] for rownum in range(1,nrows): row = table.row_values(rownum) #获取某行数据 # print(row) if row[8] == "Fail": srows +=1 # scols +=1 # list = [srows,scols] return srows #根据用例等级获取sheet总行和总列 def GetRowByLevel(path,sheetname): data = openexcel(path) table = data.sheet_by_name(sheetname) nrows = table.nrows #行数 ncols = table.ncols #列数 srows = 1 #行数 # scols = 1 #列数 levellist = GlobalClass.Level for rownum in range(1,nrows): row = table.row_values(rownum) #获取某行数据 # print(row) if float(row[9]) in levellist: srows +=1 # scols +=1 # list = [srows,scols] # print(list) return srows #根据名称获取Excel表格中的数据 def exceltablebyname(path,sheetname): data = openexcel(path) table = data.sheet_by_name(sheetname) nrows = table.nrows #行数 ncols = table.ncols colnames = table.row_values(0) #某一行数据,0表示列名所有行的所引 list =[] #把字典的Key存起来,后续通过这个Key按顺序读取 if not GlobalClass.keys: for k in range(0,ncols): GlobalClass.keys.append(colnames[k]) # print(GlobalClass.keys) for rownum in range(1,nrows): row = table.row_values(rownum) # print(row) if row: app = {} for i in range(ncols): app[colnames[i]] = row[i] list.append(app) #按Key读取的方法 # for rownum in range(0,nrows-1): # for i in range(ncols): # data = list[rownum] # print(data[keys[i]]) # print(keys) # print(list) return list #根据用例状态为Fail获取Excel表格中的数据 def exceltablebystate(path,sheetname): data = openexcel(path) table = data.sheet_by_name(sheetname) nrows = table.nrows #行数 ncols = table.ncols colnames = table.row_values(0) #某一行数据,0表示列名所有行的所引 list =[] #把字典的Key存起来,后续通过这个Key按顺序读取 if not GlobalClass.keys: for k in range(0,ncols): GlobalClass.keys.append(colnames[k]) # print(GlobalClass.keys) for rownum in range(1,nrows): row = table.row_values(rownum) #获取某行数据 # print(row) if row[8] == "Fail": if row: app = {} for i in range(ncols): app[colnames[i]] = row[i] list.append(app) #按Key读取的方法 # for rownum in range(0,nrows-1): # for i in range(ncols): # data = list[rownum] # print(data[keys[i]]) # print(keys) # print(list) return list #根据用例等级获取Excel表格中的数据 def exceltablebylevel(path,sheetname): levellist = GlobalClass.Level data = openexcel(path) table = data.sheet_by_name(sheetname) nrows = table.nrows #行数 ncols = table.ncols colnames = table.row_values(0) #某一行数据,0表示列名所有行的所引 list =[] #把字典的Key存起来,后续通过这个Key按顺序读取 if not GlobalClass.keys: for k in range(0,ncols): GlobalClass.keys.append(colnames[k]) # print(GlobalClass.keys) for rownum in range(1,nrows): row = table.row_values(rownum) #获取某行数据 # print(row) if float(row[9]) in levellist: if row: app = {} for i in range(ncols): app[colnames[i]] = row[i] list.append(app) #按Key读取的方法 # for rownum in range(0,nrows-1): # for i in range(ncols): # data = list[rownum] # print(data[keys[i]]) # print(keys) # print(list) return list
Python 读写excel类的更多相关文章
- python 全栈开发,Day86(上传文件,上传头像,CBV,python读写Excel,虚拟环境virtualenv)
一.上传文件 上传一个图片 使用input type="file",来上传一个文件.注意:form表单必须添加属性enctype="multipart/form-data ...
- [转]用Python读写Excel文件
[转]用Python读写Excel文件 转自:http://www.gocalf.com/blog/python-read-write-excel.html#xlrd-xlwt 虽然天天跟数据打交 ...
- python读写Excel文件的函数--使用xlrd/xlwt
python中读取Excel的模块或者说工具有很多,如以下几种: Packages 文档下载 说明 openpyxl Download | Documentation | Bitbucket The ...
- Python 读写 Excel(转)
Python 读写 Excel 基本上, 这个网页已经说明一切了: http://pypi.python.org/pypi/xlrd 等有时间再把这个页面写漂亮,现在先记一些代码. 读Excel 先建 ...
- Python读写Excel文件和正则表达式
Python 读写Excel文件 这里使用的是 xlwt 和 xlrd 这两个excel读写库. #_*_ coding:utf-8 _*_ #__author__='观海云不远' #__date__ ...
- Python读写EXCEL文件常用方法大全
前言 python读写excel的方式有很多,不同的模块在读写的讲法上稍有区别,这里我主要介绍几个常用的方式. 用xlrd和xlwt进行excel读写: 用openpyxl进行excel读写: 用pa ...
- Python: 读写Excel(openpyxl / win32com.client)
项目周报汇报的时候要做数据汇总,总是要从不同的excel文件中去获取数据最后汇总到一个excel表里面,所以决定用python直接写个自动化脚本来自动执行. 用python来读写excel,目前找了2 ...
- 用 Python 读写 Excel 表格
Python 可以读写 Excel 表格吗? 当然可以. Python 下有很多类库可以做到, openpyxl 就是其中的佼佼者. openpyxl 的设计非常漂亮 ,你一定会喜欢它!不信请往下看: ...
- 用Python读写Excel文件(转)
原文:google.com/ncr 虽然天天跟数据打交道,也频繁地使用Excel进行一些简单的数据处理和展示,但长期以来总是小心地避免用Python直接读写Excel文件.通常我都是把数据保存为以TA ...
随机推荐
- Struts2-052 漏洞复现
s2-052漏洞复现 参考链接: http://www.freebuf.com/vuls/147017.html http://www.freebuf.com/vuls/146718.html 漏洞描 ...
- 假设result是一个float型变量,其值为27.32,value是一个int型变量,其值为15执行以下语句后,两个便利的值分别是多少?为什么?
假设result是一个float型变量,其值为27.32,value是一个int型变量,其值为15执行以下语句后,两个便利的值分别是多少?为什么? 在执行这条语句的过程中,保存在result中的值被读 ...
- Pytorch 细节记录
1. PyTorch进行训练和测试时指定实例化的model模式为:train/eval eg: class VAE(nn.Module): def __init__(self): super(VAE, ...
- Java异常处理之try-with-resources
Oracle官方文档: http://docs.oracle.com/javase/7/docs/technotes/guides/language/try-with-resources.html 概 ...
- 使用html2canvas生成一张图片
注意事项: 1.图片生成问题,生成图片测试机正常传到正式机,无法生成!!====>>原因是正式机中,使用的是CDN加载,导致图片跨域,而canvas不支持图片跨域!!!==>> ...
- 待解决输入istream_iterator
山寨版 istream_iterator 输入 第一行是整数t,表示有t组数据,每组数据一行,三个整数加两个字符串.字符串是不含空格的. 输出 对每组数据,输出二行,在第一行输出第一个数,第二行原样输 ...
- VUE环境部署
npm install vue-router --save 下载node.js安装https://nodejs.org/en/ npm install -g cnpm --registry=http ...
- select2使用方法总结
官网:http://select2.github.io/ 调用 <link href="~/Content/select2.min.css" rel="styles ...
- NOI2019 SX 模拟赛 no.5
Mas 的童年 题目描述:不知道传送门有没有用? 反正就是对于每个前缀序列求一个断点,使得断点左右两个区间的 分别的异或和 的和最大 分析 jzoj 原题? 但是我 TM 代码没存账号也过期了啊! 然 ...
- 训练报告 (2014-2015) 2014, Samara SAU ACM ICPC Quarterfinal Qualification Contest
Solved A Gym 100488A Yet Another Goat in the Garden B Gym 100488B Impossible to Guess Solved C Gym ...