亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PyQt5+Python-docx實現(xiàn)一鍵生成測試報告

 更新時間:2025年05月04日 10:02:47   作者:Python測試之道  
作為一名測試工程師,你是否經(jīng)歷過手動填寫測試報告的痛苦,本文將用Python的PyQt5和python-docx庫,打造一款測試報告一鍵生成工具,感興趣的可以了解下

引言

作為一名測試工程師,你是否經(jīng)歷過手動填寫測試報告的痛苦?就像用放大鏡在沙地上寫詩——費力、易改、還容易被風吹散。

今天,我們將用Python的PyQt5和python-docx庫,打造一款測試報告一鍵生成工具,讓你像搭積木一樣快速完成報告,像做蛋糕一樣優(yōu)雅分配時間!

工具功能亮點

1.圖形化界面交互:你的“樂高積木”

  • 通過PyQt5設計的界面,就像一盒五顏六色的樂高積木,
  • 每個輸入框都是一個模塊,輕輕一搭,數(shù)據(jù)就位!

2.時間智能劃分:你的“時間蛋糕”大師

根據(jù)測試起止時間,像切蛋糕一樣按比例分配需求評審、

用例設計、執(zhí)行、回歸測試及報告編寫的時間。

(例如:需求評審10%、用例設計20%…)

3.模板化報告生成:你的“填字游戲”助手

基于python-docx庫,像玩填字游戲一樣自動填充Word文檔,

模板一放,數(shù)據(jù)自動到位。

4.可擴展性強:你的“建筑藍圖”

代碼結(jié)構(gòu)清晰,像建筑藍圖一樣模塊化,

方便后續(xù)集成更多功能(如圖表生成、歷史記錄保存)。

工具設計思路

1. 界面設計:PyQt5實現(xiàn)數(shù)據(jù)輸入

輸入字段:

  • 系統(tǒng)測試環(huán)境地址 → 類比為“快遞地址”,確保報告能準確送達。
  • 項目經(jīng)理、測試經(jīng)理等 → 像“團隊角色卡牌”,明確責任分工。
  • 測試起止時間 → 類比為“馬拉松起點終點”,為時間分配提供基準。
  • 用例數(shù)與Bug數(shù) → 像“考試成績表”,直觀展示測試成果。

時間智能劃分:

  • 根據(jù)起止時間,按比例分配階段時間,
  • 就像切蛋糕:需求評審(10%)、用例設計(20%)、執(zhí)行(30%)、
  • 回歸測試(20%)、報告編寫(20%)。每個階段都有清晰的“時間標簽”。

2. 文檔生成:python-docx填充模板

模板結(jié)構(gòu):

  • 標題與基本信息 → 類比為“簡歷封面”,展示項目核心信息。
  • 時間安排表 → 像“日程表”,讓時間分配一目了然。
  • 測試數(shù)據(jù)統(tǒng)計 → 如“成績單”,用表格展示用例數(shù)、Bug數(shù)。
  • 測試結(jié)論 → 類似“總結(jié)發(fā)言”,簡潔有力。

動態(tài)數(shù)據(jù)填充:

  • 通過占位符替換或直接插入段落/表格,
  • 像“填字游戲”一樣自動填充數(shù)據(jù)。

工具實現(xiàn)代碼

1. 安裝依賴

pip install PyQt5 python-docx

2. PyQt5界面代碼

import sys
from PyQt5.QtWidgets import QApplication, QWidget, QLabel, QLineEdit, QDateEdit, QPushButton, QVBoxLayout, QHBoxLayout, QFormLayout

class TestReportTool(QWidget):
    def __init__(self):
        super().__init__()
        self.setWindowTitle("測試報告一鍵生成工具")
        self.init_ui()

    def init_ui(self):
        # 表單布局
        form_layout = QFormLayout()

        # 輸入字段(積木模塊)
        self.system_url = QLineEdit()
        self.pm_name = QLineEdit()
        self.tm_name = QLineEdit()
        self.tl_name = QLineEdit()
        self.tester_name = QLineEdit()
        self.start_date = QDateEdit()
        self.end_date = QDateEdit()
        self.func_cases = QLineEdit()
        self.func_bugs = QLineEdit()
        self.regression_cases = QLineEdit()
        self.regression_bugs = QLineEdit()

        # 添加字段到表單
        form_layout.addRow("系統(tǒng)測試環(huán)境地址:", self.system_url)
        form_layout.addRow("項目經(jīng)理:", self.pm_name)
        form_layout.addRow("測試經(jīng)理:", self.tm_name)
        form_layout.addRow("測試組長:", self.tl_name)
        form_layout.addRow("測試人員:", self.tester_name)
        form_layout.addRow("測試起始時間:", self.start_date)
        form_layout.addRow("測試結(jié)束時間:", self.end_date)
        form_layout.addRow("功能測試用例數(shù):", self.func_cases)
        form_layout.addRow("功能測試Bug數(shù):", self.func_bugs)
        form_layout.addRow("回歸測試用例數(shù):", self.regression_cases)
        form_layout.addRow("回歸測試缺陷數(shù):", self.regression_bugs)

        # 生成按鈕
        self.generate_btn = QPushButton("生成測試報告")
        self.generate_btn.clicked.connect(self.generate_report)

        # 主布局
        main_layout = QVBoxLayout()
        main_layout.addLayout(form_layout)
        main_layout.addWidget(self.generate_btn)
        self.setLayout(main_layout)

    def generate_report(self):
        # 收集數(shù)據(jù)
        data = {
            "system_url": self.system_url.text(),
            "pm_name": self.pm_name.text(),
            "tm_name": self.tm_name.text(),
            "tl_name": self.tl_name.text(),
            "tester_name": self.testers_name.text(),
            "start_date": self.start_date.date().toString("yyyy-MM-dd"),
            "end_date": self.end_date.date().toString("yyyy-MM-dd"),
            "func_cases": self.func_cases.text(),
            "func_bugs": self.func_bugs.text(),
            "regression_cases": self.regression_cases.text(),
            "regression_bugs": self.regression_bugs.text(),
        }

        # 計算時間塊并添加到data
        time_blocks = calculate_time_blocks(data["start_date"], data["end_date"])
        for phase, dates in time_blocks.items():
            key = f"{phase}_time"
            data[key] = dates

        # 計算通過率
        func_pass_rate = round((1 - int(data["func_bugs"]) / int(data["func_cases"])) * 100, 2)
        data["func_pass_rate"] = f"{func_pass_rate}%"
        reg_pass_rate = round((1 - int(data["regression_bugs"]) / int(data["regression_cases"])) * 100, 2)
        data["reg_pass_rate"] = f"{reg_pass_rate}%"

        # 調(diào)用文檔生成函數(shù)
        from docx_generator import generate_docx
        generate_docx(data)
        print("測試報告生成成功!")

if __name__ == "__main__":
    app = QApplication(sys.argv)
    window = TestReportTool()
    window.show()
    sys.exit(app.exec_())

3. Word文檔生成代碼

from docx import Document
from datetime import datetime, timedelta

def calculate_time_blocks(start_date_str, end_date_str):
    start_date = datetime.strptime(start_date_str, "%Y-%m-%d")
    end_date = datetime.strptime(end_date_str, "%Y-%m-%d")
    total_days = (end_date - start_date).days
    if total_days <= 0:
        return {}
    
    # 按比例劃分階段(時間蛋糕)
    phases = {
        "需求評審": 0.1,
        "用例設計": 0.2,
        "用例執(zhí)行": 0.3,
        "回歸測試": 0.2,
        "報告編寫": 0.2
    }
    time_blocks = {}
    current_date = start_date
    for phase, ratio in phases.items():
        days = int(total_days * ratio)
        end_phase = current_date + timedelta(days=days)
        time_blocks[phase] = f"{current_date.strftime('%Y-%m-%d')} - {end_phase.strftime('%Y-%m-%d')}"
        current_date = end_phase
    return time_blocks

def generate_docx(data):
    # 讀取模板文檔
    doc = Document('template.docx')  # 假設模板文件為 template.docx

    # 替換段落中的占位符
    for paragraph in doc.paragraphs:
        for key, value in data.items():
            if key in paragraph.text:
                paragraph.text = paragraph.text.replace(f'{{{key}}}', value)  # 使用雙大括號包裹

    # 替換表格中的占位符
    for table in doc.tables:
        for row in table.rows:
            for cell in row.cells:
                for key, value in data.items():
                    if key in cell.text:
                        cell.text = cell.text.replace(f'{{{key}}}', value)

    # 保存文檔
    doc.save("TestReport.docx")

模板化樣本

# 測試報告模板(變量占位符版)
---

## 一、測試基本信息  
系統(tǒng)測試環(huán)境地址:{{{system_url}}}  
項目經(jīng)理:{{{pm_name}}}  
測試經(jīng)理:{{{tm_name}}}  
測試組長:{{{tl_name}}}  
測試人員:{{{tester_name}}}  

---

## 二、測試時間安排  
需求評審:{{{需求評審_time}}}  
用例設計:{{{用例設計_time}}}  
用例執(zhí)行:{{{用例執(zhí)行_time}}}  
回歸測試:{{{回歸測試_time}}}  
報告編寫:{{{報告編寫_time}}}  

---

## 三、測試數(shù)據(jù)統(tǒng)計  
| 測試類型 | 用例數(shù) | 缺陷數(shù) | 通過率 |  
|----------|--------|--------|--------|  
| 功能測試 | {{{func_cases}}} | {{{func_bugs}}} | {{{func_pass_rate}}} |  
| 回歸測試 | {{{regression_cases}}} | {{{regression_bugs}}} | {{{reg_pass_rate}}} |  

---

## 四、測試結(jié)論  
{{{test_conclusion}}}  

工具使用示例

1.準備模板:

  • 創(chuàng)建一個名為 template.docx 的Word文檔,內(nèi)容如上所示的模板樣本。
  • 確保模板中使用 {{{variable_name}}} 形式的占位符。

2.運行界面:

  • 打開工具后,在界面中輸入測試數(shù)據(jù)。
  • 點擊“生成測試報告”按鈕。

3.生成結(jié)果:

自動生成名為 TestReport.docx 的Word文檔,內(nèi)容如下:

  • 測試基本信息:系統(tǒng)環(huán)境、人員信息(簡歷封面)。
  • 測試時間安排:按比例劃分的各階段時間(日程表)。
  • 測試數(shù)據(jù)統(tǒng)計:用表格展示功能測試與回歸測試的用例數(shù)、缺陷數(shù)、通過率(成績單)。
  • 測試結(jié)論:簡要總結(jié)測試結(jié)果(總結(jié)發(fā)言)。

擴展建議

模板自定義:在模板中添加公司Logo、頁眉頁腳或顏色主題,提升專業(yè)度。

數(shù)據(jù)導出:集成 openpyxl 庫,將測試數(shù)據(jù)導出為Excel表格。

圖表生成:使用 matplotlib 生成缺陷趨勢圖,并嵌入到Word文檔中。

歷史記錄:將用戶輸入的數(shù)據(jù)保存為JSON文件,支持歷史記錄查詢。

結(jié)語

這款工具的核心在于將重復性工作自動化,讓測試工程師專注于測試設計與執(zhí)行。

通過PyQt5的圖形化界面和python-docx的文檔生成能力,我們不僅提高了效率,還降低了人為錯誤的風險。

到此這篇關(guān)于PyQt5+Python-docx實現(xiàn)一鍵生成測試報告的文章就介紹到這了,更多相關(guān)PyQt5 Python-docx生成測試報告內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python打印“菱形”星號代碼方法

    Python打印“菱形”星號代碼方法

    本篇文章通過代碼實例給大家詳細分析了Python打印“菱形”星號代碼方法,對此有需要的朋友參考下吧。
    2018-02-02
  • python去除空格和換行符的實現(xiàn)方法(推薦)

    python去除空格和換行符的實現(xiàn)方法(推薦)

    下面小編就為大家?guī)硪黄猵ython去除空格和換行符的實現(xiàn)方法(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • 一個不可思議的Python庫vnpy示例詳解

    一個不可思議的Python庫vnpy示例詳解

    這篇文章主要給大家介紹了關(guān)于Python庫vnpy的相關(guān)資料,vn.py是一個開源的Python交易編程框架,支持多種金融產(chǎn)品的交易,提供全流程支持,它具有模塊化設計、多語言支持、跨平臺、高性能、易用性、社區(qū)支持和文檔齊全等特性,需要的朋友可以參考下
    2024-11-11
  • Python判斷對象是否相等及eq函數(shù)的講解

    Python判斷對象是否相等及eq函數(shù)的講解

    今天小編就為大家分享一篇關(guān)于Python判斷對象是否相等及eq函數(shù)的講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • python計算寄送包裹重量的實現(xiàn)過程

    python計算寄送包裹重量的實現(xiàn)過程

    要實現(xiàn)這樣一個需求寄送包裹小于5kg,每公斤0.5元,大于等于5kg,超出5公斤部分,按照每公斤0.8元計算,輸入重量,輸出應付金額,下面小編給大家分享實現(xiàn)代碼,感興趣的朋友跟隨小編一起看看吧
    2022-02-02
  • tensorflow-gpu安裝的常見問題及解決方案

    tensorflow-gpu安裝的常見問題及解決方案

    這篇文章主要介紹了tensorflow-gpu安裝的常見問題及解決方案,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友參考下吧,需要的朋友可以參考下
    2020-01-01
  • Python處理日期方法詳細大全(30種方法)

    Python處理日期方法詳細大全(30種方法)

    這篇文章主要給大家介紹了關(guān)于Python處理日期方法詳細大全,文中共介紹了30種方法,Python程序能用很多方式處理日期和時間,轉(zhuǎn)換日期格式是一個常見的功能,Python提供了一個time和calendar模塊可以用于格式化日期和時間,需要的朋友可以參考下
    2023-12-12
  • Python實現(xiàn)緩存的兩個簡單方法

    Python實現(xiàn)緩存的兩個簡單方法

    緩存是一種用于提高應用程序性能的技術(shù),它通過臨時存儲程序獲得的結(jié)果,以便在以后需要時重用它們,本文將學習Python中的不同緩存技術(shù),感興趣的可以了解下
    2024-11-11
  • Python中使用YAML文件進行配置文件管理

    Python中使用YAML文件進行配置文件管理

    配置文件管理已經(jīng)成為了一個不可或缺的環(huán)節(jié)。它們包含了程序運行所需的各種參數(shù),本文主要介紹了Python中使用YAML文件進行配置文件管理,感興趣的可以了解一下
    2023-12-12
  • python中os包的用法

    python中os包的用法

    這篇文章主要介紹了python中os包的用法,文中給大家提到了python中os的常用方法,給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06

最新評論