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 ...
随机推荐
- IDEA-使用技巧
IDEA--个性化配置 - 心飞扬的博客 - CSDN博客--里面很好,http://blog.csdn.net/afzaici/article/details/71524643 IntelliJ I ...
- 人人中的 shiro权限管理 简单说明
maven shiro包的引用路径 :C:\Users\yanfazhongxin\.m2\repository\org\apache\shiro\shiro-core\1.3.2\shiro-co ...
- 省电优化之WakeLock
https://blog.csdn.net/qfanmingyiq/article/details/54587664 boolean onStopJob (JobParameters params) ...
- flask基本介绍及虚拟环境
Flask Flask诞生于2010年,是Armin ronacher(人名)用 Python 语言基于 Werkzeug 工具箱编写的轻量级Web开发框架. Flask 本身相当于一个内核,其他几乎 ...
- 和类相关的BIF
issubclass(class,classinfo),判断第一个参数是第二个参数的子类,这个判断是比较宽松的判断.因为第二个参数也可以是元组,并且只要参数1是元组内任意一个元素的子元素,就会返回Tr ...
- Zookeeper学习笔记1
参考:从Paxos到Zookeeper分布式一致性原理与实践 从ACID到CAP/BASE ACID 事务(Transaction),一般是指要做的或所做的事情.在计算机术语中是指访问并可能更新数据库 ...
- Excel自动建组
已用于测试用例自动创建组 使用要求:A列的格式如:X.X.X.X.X11.11.1.11.1.1.11.1.1.1.11.1.1.21.1.21.22 会自动将1.1.1.1.1-1.1.1.1.X组 ...
- 关于session,cookie,Cache
昨天看了<ASP.NET 页面之间传值的几种方式>之后,对session,cookie,Cache有了更近一步的了解,以下是相关的内容 一.Session 1.Session基本操作 a. ...
- codeforces 38G - Queue splay伸展树
题目 https://codeforces.com/problemset/problem/38/G 题意: 一些人按顺序进入队列,每个人有两个属性,地位$A$和能力$C$ 每个人进入时都在队尾,并最多 ...
- sonar——"entrySet()" should be iterated when both the key and value are needed
When only the keys from a map are needed in a loop, iterating the keySet makes sense. But when both ...