python 根据测试结果统计测试次数,成功率和失败原因写入excel表格

要根据测试结果统计测试次数、成功率并记录失败原因,并将这些数据写入Excel表格,可以使用Python的pandas库来处理数据和openpyxl库来写入Excel。假设您已经有一个包含测试结果的列表,每个元素是一个字典,包含test_name(测试名称)、result(测试结果,True表示成功,False表示失败)和failure_reason(失败原因,仅在结果为False时提供)。以下是一个示例:

 

python

import pandas as pd
from openpyxl import Workbook

# 假设您的测试结果列表如下:
test_results = [
    {"test_name": "Test_1", "result": True},
    {"test_name": "Test_2", "result": False, "failure_reason": "Timeout Error"},
    {"test_name": "Test_3", "result": True},
    # 更多测试结果...
]

# 将测试结果列表转换为DataFrame
df = pd.DataFrame(test_results)

# 统计测试次数、成功率
total_tests = len(df)
success_count = df[df["result"]].shape[0]
success_rate = success_count / total_tests * 100

# 记录失败原因
failure_reasons = df[df["result"] == False]["failure_reason"].tolist()

# 将统计结果添加到DataFrame
df_summary = pd.DataFrame({
    "Total Tests": [total_tests],
    "Success Count": [success_count],
    "Success Rate": [success_rate],
    "Failure Reasons": [failure_reasons]
}, index=["Summary"])

# 将所有数据合并到一个DataFrame
full_df = pd.concat([df, df_summary], ignore_index=False)

# 写入Excel文件
with pd.ExcelWriter("test_report.xlsx", engine="openpyxl") as writer:
    full_df.to_excel(writer, sheet_name="Test Results", index=False)

    # 保存并关闭工作簿
    workbook = writer.book
    workbook.save()

在这个示例中:

  1. 首先,我们创建一个包含测试结果的DataFrame。
  2. 然后,计算总测试次数、成功次数和成功率,并将这些统计信息放入一个新的DataFrame(df_summary)。
  3. 将原始测试结果和统计信息合并到一个完整的DataFrame(full_df)。
  4. 最后,使用pd.ExcelWriterfull_df写入名为"test_report.xlsx"的Excel文件,其中包含一个名为"Test Results"的工作表。

请根据实际的测试结果数据结构调整上述代码。注意,此示例中失败原因以列表形式存储在一个单元格中,如果需要将每个失败原因单独写入一行,可以稍作修改。

  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

三希

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值