python提效小工具之统计xmind用例数量(源码)

作者:淘气的包子 时间:2021-11-26 21:42:44 

使用Python读取解析xmind文件,一键统计测试用例数量。

问题:做测试的朋友们经常会用到xmind这个工具来梳理测试点或写测试用例,但是xmind8没有自带的统计测试用例,其他版本的xmind有些自带节点数量统计功能,但也也不会累计最终的数量,导致统计测试工作量比较困难。

解决方法:利用python开发小工具,实现同一份xmind文件中一个或多个sheet页的用例数量统计功能。

一、源码

#!/usr/bin/env python
# -*- coding:utf-8 -*-
__author__ = 'zhongxintao'
import tkinter as tk
from tkinter import filedialog, messagebox
from xmindparser import xmind_to_dict
import xmind

class ParseXmind:
   def __init__(self, root):
       self.count = 0
       self.case_fail = 0
       self.case_success = 0
       self.case_block = 0
       self.case_priority = 0

# total汇总用
       self.total_cases = 0
       self.total_success = 0
       self.total_fail = 0
       self.total_block = 0
       self.toal_case_priority = 0

# 设置弹框标题、初始位置、默认大小
       root.title(u'xmind文件解析及用例统计工具')
       width = 760
       height = 600
       xscreen = root.winfo_screenwidth()
       yscreen = root.winfo_screenheight()
       xmiddle = (xscreen - width) / 2
       ymiddle = (yscreen - height) / 2
       root.geometry('%dx%d+%d+%d' % (width, height, xmiddle, ymiddle))

# 设置2个Frame
       self.frm1 = tk.Frame(root)
       self.frm2 = tk.Frame(root)

# 设置弹框布局
       self.frm1.grid(row=1, padx='20', pady='20')
       self.frm2.grid(row=2, padx='30', pady='30')

self.but_upload = tk.Button(self.frm1, text=u'上传xmind文件', command=self.upload_files, bg='#dfdfdf')
       self.but_upload.grid(row=0, column=0, pady='10')
       self.text = tk.Text(self.frm1, width=55, height=10, bg='#f0f0f0')
       self.text.grid(row=1, column=0)
       self.but2 = tk.Button(self.frm2, text=u"开始统计", command=self.new_lines, bg='#dfdfdf')
       self.but2.grid(row=0, columnspan=6, pady='10')
       self.label_file = tk.Label(self.frm2, text=u"文件名", relief='groove', borderwidth='2', width=25,
                                  bg='#FFD0A2')
       self.label_file.grid(row=1, column=0)
       self.label_case = tk.Label(self.frm2, text=u"用例数", relief='groove', borderwidth='2', width=10,
                                  bg='#FFD0A2').grid(row=1, column=1)
       self.label_pass = tk.Label(self.frm2, text=u"成功", relief='groove', borderwidth='2', width=10,
                                  bg='#FFD0A2').grid(row=1, column=2)
       self.label_fail = tk.Label(self.frm2, text=u"失败", relief='groove', borderwidth='2', width=10,
                                  bg='#FFD0A2').grid(row=1, column=3)
       self.label_block = tk.Label(self.frm2, text=u"阻塞", relief='groove', borderwidth='2', width=10,
                                   bg='#FFD0A2').grid(row=1, column=4)
       self.label_case_priority = tk.Label(self.frm2, text="p0case", relief='groove', borderwidth='2',
                                           width=10, bg='#FFD0A2').grid(row=1, column=5)

def count_case(self, li):
       """统计xmind中的用例数"""
       for i in range(len(li)):
           if li[i].__contains__('topics'):
               # 带topics标签表示有子标题,递归执行方法
               self.count_case(li[i]['topics'])
               # 不带topics表示无子标题,此级别即是用例
           else:
               # 有标记成功或失败时会有makers标签
               if li[i].__contains__('makers'):
                   for mark in li[i]['makers']:
                       # 成功
                       if mark == "symbol-right":
                           self.case_success += 1
                       # 失败
                       elif mark == "symbol-wrong":
                           self.case_fail += 1
                       # 阻塞
                       elif mark == "symbol-attention":
                           self.case_block += 1
                       # 优先级
                       elif mark == "priority-1":
                           self.case_priority += 1
               # 用例总数
               self.count += 1

def new_line(self, filename, row_number):
       """用例统计表新增一行"""
       # sheets是一个list,可包含多sheet页
       sheets = xmind_to_dict(filename)  # 调用此方法,将xmind转成字典
       for sheet in sheets:
           print(sheet)
           # 字典的值sheet['topic']['topics']是一个list
           my_list = sheet['topic']['topics']
           print(my_list)
           self.count_case(my_list)

# 插入一行统计数据
       lastname = filename.split('/')
       self.label_file = tk.Label(self.frm2, text=lastname[-1], relief='groove', borderwidth='2', width=25)
       self.label_file.grid(row=row_number, column=0)

self.label_case = tk.Label(self.frm2, text=self.count, relief='groove', borderwidth='2', width=10)
       self.label_case.grid(row=row_number, column=1)
       self.label_pass = tk.Label(self.frm2, text=self.case_success, relief='groove', borderwidth='2',
                                  width=10)
       self.label_pass.grid(row=row_number, column=2)
       self.label_fail = tk.Label(self.frm2, text=self.case_fail, relief='groove', borderwidth='2', width=10)
       self.label_fail.grid(row=row_number, column=3)
       self.label_block = tk.Label(self.frm2, text=self.case_block, relief='groove', borderwidth='2', width=10)
       self.label_block.grid(row=row_number, column=4)
       self.label_case_priority = tk.Label(self.frm2, text=self.case_priority, relief='groove', borderwidth='2',
                                           width=10)
       self.label_case_priority.grid(row=row_number, column=5)
       self.total_cases += self.count
       self.total_success += self.case_success
       self.total_fail += self.case_fail
       self.total_block += self.case_block
       self.toal_case_priority += self.case_priority

def new_lines(self):
       """用例统计表新增多行"""
       # 从text中获取所有行
       lines = self.text.get(1.0, tk.END)
       row_number = 2
       # 分隔成每行
       for line in lines.splitlines():
           if line == '':
               break
           print(line)
           self.new_line(line, row_number)
           row_number += 1

# total汇总行
       self.label_file = tk.Label(self.frm2, text='total', relief='groove', borderwidth='2', width=25)
       self.label_file.grid(row=row_number, column=0)
       self.label_case = tk.Label(self.frm2, text=self.total_cases, relief='groove', borderwidth='2', width=10)
       self.label_case.grid(row=row_number, column=1)

self.label_pass = tk.Label(self.frm2, text=self.total_success, relief='groove', borderwidth='2',
                                  width=10)
       self.label_pass.grid(row=row_number, column=2)
       self.label_fail = tk.Label(self.frm2, text=self.total_fail, relief='groove', borderwidth='2', width=10)
       self.label_fail.grid(row=row_number, column=3)
       self.label_block = tk.Label(self.frm2, text=self.total_block, relief='groove', borderwidth='2',
                                   width=10)
       self.label_block.grid(row=row_number, column=4)

self.label_case_priority = tk.Label(self.frm2, text=self.toal_case_priority, relief='groove',
                                           borderwidth='2',
                                           width=10)
       self.label_case_priority.grid(row=row_number, column=5)

def upload_files(self):
       """上传多个文件,并插入text中"""
       select_files = tk.filedialog.askopenfilenames(title=u"可选择1个或多个文件")
       for file in select_files:
           self.text.insert(tk.END, file + '\n')
           self.text.update()
if __name__ == '__main__':
   r = tk.Tk()
   ParseXmind(r)
   r.mainloop()

二、工具使用说明

1、xmind文件中使用下列图标进行分类标识:

标记表示p0级别case:数字1

标记表示执行通过case:绿色√

标记表示执行失败case:红色×

标记表示执行阻塞case:橙色!

2、执行代码

3、在弹框内【上传xmind文件】按钮

4、在弹框内【开始统计】按钮

三、实现效果

python提效小工具之统计xmind用例数量(源码)

来源:https://www.cnblogs.com/zxt518/p/16793800.html

标签:python,xmind,工具
0
投稿

猜你喜欢

  • conda与jupyter notebook kernel核环境不一致的问题解决

    2021-07-03 15:43:02
  • TensorFlow实现Logistic回归

    2023-11-27 18:49:14
  • Python谱减法语音降噪实例

    2023-07-26 05:19:55
  • PHP实现上传文件并存进数据库的方法

    2023-07-03 21:35:14
  • 如何用ASP发送HTML格式的邮件?

    2010-06-11 19:41:00
  • Django 解决开发自定义抛出异常的问题

    2023-03-05 12:43:55
  • MySQL Union合并查询数据及表别名、字段别名用法分析

    2024-01-16 04:44:27
  • IE6终极备忘单——策略

    2010-01-13 13:05:00
  • 15个短代码示例理解python丰富的编程思维

    2022-07-18 08:16:57
  • 对python3标准库httpclient的使用详解

    2021-09-07 06:48:02
  • Javascript模拟加速运动与减速运动代码分享

    2024-06-07 15:27:46
  • Python实现大数据收集至excel的思路详解

    2022-02-03 10:25:25
  • ASP新闻分页,将一篇过长的文章分页,生成静态页面

    2011-04-10 11:14:00
  • Python实现以主程序的形式执行模块

    2022-01-14 01:37:00
  • sql存储过程详解

    2024-01-22 07:00:39
  • Python爬虫beautifulsoup4常用的解析方法总结

    2022-09-01 11:58:54
  • python使用redis模块来跟redis实现交互

    2023-05-06 04:13:40
  • Javascript 实现的数独解题算法网页实例

    2024-02-26 15:26:16
  • 简单三步实现报表页面集成天气

    2024-04-25 13:08:16
  • python实现多张图片拼接成大图

    2021-11-19 08:36:53
  • asp之家 网络编程 m.aspxhome.com