【Python】把指定组织形式的txt转换为xmind

2024-06-07 06:04

本文主要是介绍【Python】把指定组织形式的txt转换为xmind,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

人工智能训练通常需要使用文本格式,把基于训练之后的内容,让GLM大模型输出如下格式的文本:

weltestDemo|#|weltest|#|静态界面|#|输入|#|长度|#|不超过四位
weltestDemo|#|weltest|#|静态界面|#|输入|#|长度|#|不超过五位
weltestDemo|#|weltest|#|静态界面|#|输入|#|长度|#|不超过6位
weltestDemo|#|weltest|#|静态界面|#|输入2|#|不超过四位
weltestDemo|#|weltest|#|静态界面|#|输入2|#|不超过五位
weltestDemo|#|weltest|#|静态界面|#|输入2|#|不超过6位
weltestDemo|#|weltest|#|功能测试|#|输入|#|长度|#|不超过四位
weltestDemo|#|weltest|#|功能测试|#|输入|#|长度|#|不超过五位
weltestDemo|#|weltest|#|功能测试|#|输入|#|长度|#|不超过6位
weltestDemo|#|weltest|#|功能测试|#|输入2|#|不超过四位
weltestDemo|#|weltest|#|功能测试|#|输入2|#|不超过五位
weltestDemo|#|weltest|#|功能测试|#|输入2|#|不超过6位

如何把上述文本转换为xmind格式呢?

软件信息

python

python -v

Python 3.9.13 (tags/v3.9.13:6de2ca5, May 17 2022, 16:36:42) [MSC v.1929 64 bit (AMD64)] on win32
依赖库

pip install XMind==1.2.0

xmind版本

XMind 8 Update 7 (R3.7.7.201801311814)

在这里插入图片描述

程序脚本

#!/usr/bin/python3
# -*- coding: utf-8 -*-
import os,re
import xmind
def txt2Xmind(txt_file=r'weltestDemo.txt'):filename,_=os.path.splitext(os.path.basename(txt_file))print(filename)with open(txt_file,'r',encoding='UTF-8') as xfile:lines=xfile.readlines()if os.path.exists(f"{filename}.xmind"):os.remove(f"{filename}.xmind")wk = xmind.load(f"{filename}.xmind")rootset = lines[0].strip('\n').split('|#|')picture = wk.getPrimarySheet()picture.setTitle(rootset[0])root = picture.getRootTopic()root.setTitle(rootset[1])preitems=lines[0].strip('\n').split('|#|')current_topic=rootfor line in lines:items=line.strip('\n').split('|#|')last_index=len(set(items)&set(preitems))diff_record=len(set(items)-set(preitems))current_length=len(set(items))print(str(items)+str(current_length)+'items')print(str(preitems)+'preitems')#print(str(set(items)&set(preitems))+'inter')expect_topic_title=items[last_index-1]#print(current_topic.getTitle()+'root')if diff_record==0:for sub in items[2:]:current_topic=current_topic.addSubTopic()current_topic.setTitle(sub)else:root_index=preitems.index(root.getTitle())expect_index=preitems.index(expect_topic_title)#距离根节点的距离distance=expect_index-root_indextmp = rootfor i in range(1,distance+1):subtopics=[item for item  in tmp.getSubTopics() if item.getTitle()==preitems[root_index+i]]tmp=subtopics[0]print(tmp.getTitle())current_topic=tmpfor sub in items[current_length-diff_record:]:current_topic=current_topic.addSubTopic()current_topic.setTitle(sub)preitems = itemsxmind.save(wk, f"{filename}.xmind")if __name__=="__main__":txt2Xmind()

操作演示

weltestDemo.txt
weltestDemo|#|weltest|#|静态界面|#|输入|#|长度|#|不超过四位
weltestDemo|#|weltest|#|静态界面|#|输入|#|长度|#|不超过五位
weltestDemo|#|weltest|#|静态界面|#|输入|#|长度|#|不超过6位
weltestDemo|#|weltest|#|静态界面|#|输入2|#|不超过四位
weltestDemo|#|weltest|#|静态界面|#|输入2|#|不超过五位
weltestDemo|#|weltest|#|静态界面|#|输入2|#|不超过6位
weltestDemo|#|weltest|#|功能测试|#|输入|#|长度|#|不超过四位
weltestDemo|#|weltest|#|功能测试|#|输入|#|长度|#|不超过五位
weltestDemo|#|weltest|#|功能测试|#|输入|#|长度|#|不超过6位
weltestDemo|#|weltest|#|功能测试|#|输入2|#|不超过四位
weltestDemo|#|weltest|#|功能测试|#|输入2|#|不超过五位
weltestDemo|#|weltest|#|功能测试|#|输入2|#|不超过6位
执行命令

调整脚本中文件名称为“weltestDemo.txt”,可以依据自己需要进行调整

(venv) PS D:\Python\xmind> python .\txt2xmind.py
weltestDemo
['weltestDemo', 'weltest', '静态界面', '输入', '长度', '不超过四位']6items
['weltestDemo', 'weltest', '静态界面', '输入', '长度', '不超过四位']preitems
['weltestDemo', 'weltest', '静态界面', '输入', '长度', '不超过五位']6items
['weltestDemo', 'weltest', '静态界面', '输入', '长度', '不超过四位']preitems
静态界面
输入
长度
['weltestDemo', 'weltest', '静态界面', '输入', '长度', '不超过6位']6items
['weltestDemo', 'weltest', '静态界面', '输入', '长度', '不超过五位']preitems
静态界面
输入
长度
['weltestDemo', 'weltest', '静态界面', '输入2', '不超过四位']5items
['weltestDemo', 'weltest', '静态界面', '输入', '长度', '不超过6位']preitems
静态界面
['weltestDemo', 'weltest', '静态界面', '输入2', '不超过五位']5items
['weltestDemo', 'weltest', '静态界面', '输入2', '不超过四位']preitems
静态界面
输入2
['weltestDemo', 'weltest', '静态界面', '输入2', '不超过6位']5items
['weltestDemo', 'weltest', '静态界面', '输入2', '不超过五位']preitems
静态界面
输入2
['weltestDemo', 'weltest', '功能测试', '输入', '长度', '不超过四位']6items
['weltestDemo', 'weltest', '静态界面', '输入2', '不超过6位']preitems
['weltestDemo', 'weltest', '功能测试', '输入', '长度', '不超过五位']6items
['weltestDemo', 'weltest', '功能测试', '输入', '长度', '不超过四位']preitems
功能测试
输入
长度
['weltestDemo', 'weltest', '功能测试', '输入', '长度', '不超过6位']6items
['weltestDemo', 'weltest', '功能测试', '输入', '长度', '不超过五位']preitems
功能测试
输入
长度
['weltestDemo', 'weltest', '功能测试', '输入2', '不超过四位']5items
['weltestDemo', 'weltest', '功能测试', '输入', '长度', '不超过6位']preitems
功能测试
['weltestDemo', 'weltest', '功能测试', '输入2', '不超过五位']5items
['weltestDemo', 'weltest', '功能测试', '输入2', '不超过四位']preitems
功能测试
输入2
['weltestDemo', 'weltest', '功能测试', '输入2', '不超过6位']5items
['weltestDemo', 'weltest', '功能测试', '输入2', '不超过五位']preitems
功能测试
输入2
(venv) PS D:\Python\xmind>
最后结果

在这里插入图片描述

现存问题

由下面两行代码实现,引入了一个问题:画布名称和主题名称不能一致,不然会提示越界情况

root_index=preitems.index(root.getTitle())
expect_index=preitems.index(expect_topic_title)

这篇关于【Python】把指定组织形式的txt转换为xmind的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1038350

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

nudepy,一个有趣的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个有趣的 Python 库 - nudepy。 Github地址:https://github.com/hhatto/nude.py 在图像处理和计算机视觉应用中,检测图像中的不适当内容(例如裸露图像)是一个重要的任务。nudepy 是一个基于 Python 的库,专门用于检测图像中的不适当内容。该

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',

遮罩,在指定元素上进行遮罩

废话不多说,直接上代码: ps:依赖 jquer.js 1.首先,定义一个 Overlay.js  代码如下: /*遮罩 Overlay js 对象*/function Overlay(options){//{targetId:'',viewHtml:'',viewWidth:'',viewHeight:''}try{this.state=false;//遮罩状态 true 激活,f

Jenkins构建Maven聚合工程,指定构建子模块

一、设置单独编译构建子模块 配置: 1、Root POM指向父pom.xml 2、Goals and options指定构建模块的参数: mvn -pl project1/project1-son -am clean package 单独构建project1-son项目以及它所依赖的其它项目。 说明: mvn clean package -pl 父级模块名/子模块名 -am参数

PDF 软件如何帮助您编辑、转换和保护文件。

如何找到最好的 PDF 编辑器。 无论您是在为您的企业寻找更高效的 PDF 解决方案,还是尝试组织和编辑主文档,PDF 编辑器都可以在一个地方提供您需要的所有工具。市面上有很多 PDF 编辑器 — 在决定哪个最适合您时,请考虑这些因素。 1. 确定您的 PDF 文档软件需求。 不同的 PDF 文档软件程序可以具有不同的功能,因此在决定哪个是最适合您的 PDF 软件之前,请花点时间评估您的