zoukankan      html  css  js  c++  java
  • 使用python把xmind文件转换为xlsx文件测试用例

    用例的格式可以自己修改

    import xlwt,xlrd
    from xmindparser import xmind_to_dict
    from openpyxl.styles import Font
    from openpyxl import load_workbook


    def resolvePath(dict,lists,title):
    # title去除首尾空格
    title = title.strip()
    # 如果title是空字符串,则直接获取value
    if len(title) == 0:
    concatTitle = dict['title'].strip()
    # print(concatTitle)
    else:
    concatTitle = title + ' ' + dict['title'].strip()

    if dict.__contains__('topics')==False:
    lists.append(concatTitle)
    else:
    for d in dict['topics']:
    resolvePath(d,lists,concatTitle)


    def xmind_cat(list,excelname):
    # print(f'list是{list}')
    # print(list)

    f = xlwt.Workbook()
    # 生成excel文件,单sheet,sheet名为:out1["title"]
    out1 = xmind_to_dict(filename)[0]["topic"]
    sheet = f.add_sheet(out1["title"] , cell_overwrite_ok=True)


    row0 = [ '用例标题','步骤','预期', '用例类型','使用阶段']
    # 生成第一行中固定表头内容
    for i in range(0, len(row0)):
    sheet.write(0, i, row0[i])

    # 增量索引
    index = 0

    for h in range(0,len(list)):
    lists = []
    resolvePath(list[h], lists, '')
    for j in range(0, len(lists)):
    # print(lists)

    lists[j] = lists[j].split(' ')

    for n in range(0, len(lists[j])):
    # print(lists[j][n])
    out1 = xmind_to_dict(filename)[0]["topic"]
    # 获取xmind的中心主题,拼接用例
    ii = out1["title"]+"-".join(lists[j])
    # print(lists[j])
    # 获取预期结果
    jj = lists[j][-1]
    # 写入表中
    sheet.write(j+index+1,0,ii)
    sheet.write(j+index+1,1,ii)
    sheet.write(j+index+1,2,jj)
    sheet.write(j+index+1,3,'功能测试')
    sheet.write(j+index+1,4,'系统测试阶段')


    # 遍历结束lists,给增量索引赋值,跳出for j循环,开始for h循环
    if j == len(lists) - 1:
    index += len(lists)

    f.save(excelname)

    def maintest( filename):
    out = xmind_to_dict(filename)
    excelname = filename.split('/')[-1].split('.')[0] + '.xlsx'
    xmind_cat(out[0]['topic']['topics'],excelname)
    # 获取文档的用例数
    filepath= excelname
    wb= xlrd.open_workbook(filepath)
    out1 = xmind_to_dict(filename)[0]["topic"]
    sheet1 =wb.sheet_by_name(out1["title"])
    n = sheet1.nrows-1
    print("用例数为:",n)


    if __name__ == '__main__':
    filename = 'xmind文件路径'
    maintest(filename)
  • 相关阅读:
    PowerShell里的数组
    题解 cf gym 103261 D FFT Algorithm
    欧拉筛求积性函数的一般形式
    题解 LOJ 6053
    题解 SP34112 UDIVSUM
    题解 luogu P5162 WD与积木
    Java 关闭流同步输入输出
    题解 luogu P6620 [省选联考 2020 A 卷] 组合数问题
    hdu 6588 题解
    题解 cf gym 102979 E Expected Distance
  • 原文地址:https://www.cnblogs.com/lldk/p/15207994.html
Copyright © 2011-2022 走看看