用python实现xmind用例转换为excel/csv用例

python 复制代码
from xmindparser import xmind_to_dict
from openpyxl import Workbook

# 解析XMind文件
xmind_file = 'path/to/xmind/file.xmind'
xmind_data = xmind_to_dict(xmind_file)

# 创建Excel文件
excel_file = 'path/to/excel/file.xlsx'
wb = Workbook()
ws = wb.active

# 定义用例表格的列名
ws['A1'] = 'Title'
ws['B1'] = 'Description'
ws['C1'] = 'Priority'
ws['D1'] = 'Steps'
ws['E1'] = 'Expected Result'

# 获取用例数据
case_data = xmind_data['topics'][0]  # 假设用例数据在第一个主题下

# 将用例数据写入Excel文件
row = 2  # 从第二行开始写入数据

def process_topic(topic):
    global row
    title = topic['title']
    description = topic['topics'][0]['title']
    priority = topic['topics'][0]['topics'][0]['title']
    steps = topic['topics'][0]['topics'][0]['topics']
    for step in steps:
        step_title = step['title']
        step_description = step['topics'][0]['title']
        # 将用例数据写入Excel文件的相应单元格
        ws[f'A{row}'] = title
        ws[f'B{row}'] = description
        ws[f'C{row}'] = priority
        ws[f'D{row}'] = step_title
        ws[f'E{row}'] = step_description
        row += 1

process_topic(case_data)

# 保存Excel文件
wb.save(excel_file)

xmind转换成csv

python 复制代码
import csv
from xmindparser import xmind_to_dict

# 解析XMind文件
xmind_file = 'path/to/xmind/file.xmind'
xmind_data = xmind_to_dict(xmind_file)

# 创建CSV文件
csv_file = 'path/to/csv/file.csv'
csv_columns = ['Title', 'Description', 'Priority', 'Steps', 'Expected Result']
csv_data = []

# 获取用例数据
case_data = xmind_data['topics'][0]  # 假设用例数据在第一个主题下

def process_topic(topic):
    title = topic['title']
    description = topic['topics'][0]['title']
    priority = topic['topics'][0]['topics'][0]['title']
    steps = topic['topics'][0]['topics'][0]['topics']
    for step in steps:
        step_title = step['title']
        step_description = step['topics'][0]['title']
        # 将用例数据添加到CSV数据列表中
        csv_data.append({
            'Title': title,
            'Description': description,
            'Priority': priority,
            'Steps': step_title,
            'Expected Result': step_description
        })

process_topic(case_data)

# 将CSV数据写入CSV文件
with open(csv_file, 'w', newline='') as file:
    writer = csv.DictWriter(file, fieldnames=csv_columns)
    writer.writeheader()
    for data in csv_data:
        writer.writerow(data)
相关推荐
zone773919 小时前
001:简单 RAG 入门
后端·python·面试
F_Quant19 小时前
🚀 Python打包踩坑指南:彻底解决 Nuitka --onefile 配置文件丢失与重启报错问题
python·操作系统
允许部分打工人先富起来20 小时前
在node项目中执行python脚本
前端·python·node.js
IVEN_21 小时前
Python OpenCV: RGB三色识别的最佳工程实践
python·opencv
haosend21 小时前
AI时代,传统网络运维人员的转型指南
python·数据网络·网络自动化
曲幽1 天前
不止于JWT:用FastAPI的Depends实现细粒度权限控制
python·fastapi·web·jwt·rbac·permission·depends·abac
IVEN_2 天前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang2 天前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮2 天前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling2 天前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python