#-*- 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类的更多相关文章

  1. python 全栈开发,Day86(上传文件,上传头像,CBV,python读写Excel,虚拟环境virtualenv)

    一.上传文件 上传一个图片 使用input type="file",来上传一个文件.注意:form表单必须添加属性enctype="multipart/form-data ...

  2. [转]用Python读写Excel文件

    [转]用Python读写Excel文件   转自:http://www.gocalf.com/blog/python-read-write-excel.html#xlrd-xlwt 虽然天天跟数据打交 ...

  3. python读写Excel文件的函数--使用xlrd/xlwt

    python中读取Excel的模块或者说工具有很多,如以下几种: Packages 文档下载 说明 openpyxl Download | Documentation | Bitbucket  The ...

  4. Python 读写 Excel(转)

    Python 读写 Excel 基本上, 这个网页已经说明一切了: http://pypi.python.org/pypi/xlrd 等有时间再把这个页面写漂亮,现在先记一些代码. 读Excel 先建 ...

  5. Python读写Excel文件和正则表达式

    Python 读写Excel文件 这里使用的是 xlwt 和 xlrd 这两个excel读写库. #_*_ coding:utf-8 _*_ #__author__='观海云不远' #__date__ ...

  6. Python读写EXCEL文件常用方法大全

    前言 python读写excel的方式有很多,不同的模块在读写的讲法上稍有区别,这里我主要介绍几个常用的方式. 用xlrd和xlwt进行excel读写: 用openpyxl进行excel读写: 用pa ...

  7. Python: 读写Excel(openpyxl / win32com.client)

    项目周报汇报的时候要做数据汇总,总是要从不同的excel文件中去获取数据最后汇总到一个excel表里面,所以决定用python直接写个自动化脚本来自动执行. 用python来读写excel,目前找了2 ...

  8. 用 Python 读写 Excel 表格

    Python 可以读写 Excel 表格吗? 当然可以. Python 下有很多类库可以做到, openpyxl 就是其中的佼佼者. openpyxl 的设计非常漂亮 ,你一定会喜欢它!不信请往下看: ...

  9. 用Python读写Excel文件(转)

    原文:google.com/ncr 虽然天天跟数据打交道,也频繁地使用Excel进行一些简单的数据处理和展示,但长期以来总是小心地避免用Python直接读写Excel文件.通常我都是把数据保存为以TA ...

随机推荐

  1. 加扰与加密&解扰与解密

    原文:https://blog.csdn.net/yuan892173701/article/details/8743543 加扰就是改变标准电视信号的特性,在发送端按规定处理,而加密就是在加解扰系统 ...

  2. 关于VXLAN的认识-----基础知识

    一.什么是VXLAN 普通的VLAN数量只有4096个,无法满足大规模云计算IDC的需求,因为目前大部分IDC内部结构主要分为两种L2,L3. L2结构里面,所有的服务器都在一个大的局域网里面,TOR ...

  3. springboot整合dubbo\zookeeper做注册中心

    springboot整合dubbo发布服务,zookeeper做注册中心.前期的安装zookeeper以及启动zookeeper集群就不说了. dubbo-admin-2.5.4.war:dubbo服 ...

  4. Curator实现分布式锁

    分布式锁的应用 分布式锁服务宕机, ZooKeeper 一般是以集群部署, 如果出现 ZooKeeper 宕机, 那么只要当前正常的服务器超过集群的半数, 依然可以正常提供服务 持有锁资源服务器宕机, ...

  5. android PopupWindow 显示问题

    设置可点击,其余控件也可点击,等操作 setOutsideTouchable(true);   setBackgroundDrawable(new BitmapDrawable()); setTouc ...

  6. 基于FATFS的磁盘分布

    1.前言 本文主要采用FAT32文件系统的磁盘各个部分是如何划分的 2. 磁盘分布总图 如包含两个分区的磁盘整体分布如下: 图 带有两个分区的磁盘分布 2.1 MBR 图  MBR的高层视图 主引导记 ...

  7. React组件State提升(译)

    译自:https://reactjs.org/docs/lifting-state-up.html (适当进行了裁减) 通常我们会碰到这样的情况,当某个组件的state数据改变时,几个React组件同 ...

  8. 美团点评基于MGR的CMDB高可用架构搭建之路【转】

    王志朋 美团点评DBA 曾在京东金融担任DBA,目前就职于美团点评,主要负责金融业务线数据库及基础组件数据库的运维. MySQL Group Replication(以下简称MGR),于5.7.17版 ...

  9. H5混合开发app常用代码

    1.Android与H5互调可以让我们的实现混合开发,至于混合开发就是在一个App中内嵌一个轻量级的浏览器(高性能webkit内核浏览器),一部分原生的功能改为Html 5来开发.然后这个浏览器又封装 ...

  10. 前端跨域问题的总结&&nodejs 中间层的路由转发

    前后端交互的时候,跨域是避不开的问题. 总结就是如下: 1.Cors 我在做前后端分离的时候,会采用cors 的方法:便于其他源的调用接口,这个可以设置成任意的源头,也可以允许指定的源头. 下面的是n ...