利用Python开发Markdown表格结构转换为Excel工具

2025-03-28 02:50

本文主要是介绍利用Python开发Markdown表格结构转换为Excel工具,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一...

在数据管理和文档编写过程中,我们经常使用 Markdown 来记录表格数据。然而,Markdown 格式的表格在实际应用中不如 Excel 方便,特别是需要进一步处理数据时。因此,我们开发了一个使用 wxpython 的 GUI 工具,将 Markdown 表格结构转换为 Excel 文件。

利用Python开发Markdown表格结构转换为Excel工具

1.完整代码

import wx
import re
import openpyxl
import logging

class MarkdownToExcelApp(wx.Frame):
    def __init__(self):
        super().__init__(parent=None, title="利用Python开发Markdown表格结构转换为Excel工具", size=(800, 600))
        
        # 配置日志
        logging.basicConfig(level=logging.DEBUG, 
                            format='%(asctime)s - %(levelname)s - %(message)s',
                            filename='markdown_to_excel_debug.log',
                            filemode='w')
        
        # 创建面板
        panel = wx.Panel(self)
        
        # 创建垂直布局
        main_sizer = wx.BoxSizer(wx.VERTICAL)
        
        # 输入标签
        input_label = wx.StaticText(panel, label='请输入Markdown表格结构:')
        main_sizer.Add(input_label, 0, wx.ALL | wx.EXPAND, 10)
        
        # 输入文本框
        self.input_text = wx.TextCtrl(panel, style=wx.TE_MULTILINE)
        main_sizer.Add(self.input_text, 1, wx.ALL | wx.EXPAND, 10)
        
        # 转换按钮
        convert_btn = wx.Button(panel, label='转换为Excel')
        convert_btn.Bind(wx.EVT_BUTTON, self.on_convert)
        main_sizer.Add(convert_btn, 0, wx.ALL | wx.CENTER, 10)
        
        # 日志文本框
      python  self.log_text = wx.TextCtrl(panel, style=wx.TE_MULTILINE | wx.TE_READONLY)
        main_sizer.AChina编程dd(self.log_text, 1, wx.ALL | wx.EXPAND, 10)
        
        # 设置面板的布局
        panel.SetSizer(main_sizer)
        
        # 创建菜单栏
        menubar = wx.MenuBar()
        file_menu = wx.Menu()
        exit_item = file_menu.Append(wx.ID_EXIT, '退出', '退出应用程序')
        menubar.Append(file_menu, '文件')
        self.SetMenuBar(menubar)
        
        # 绑定菜单事件
        self.Bind(wx.EVT_MENU, self.on_exit, exit_item)
        
        # 居中显示
        self.Centre()
    
    def log_and_display(self, message):
        """记录日志并在界面显示"""
        logging.debug(message)
        self.log_text.AppendText(message + '\n')
    
    def parse_markdown_structure(self, markdown_text):
        """解析Markdown表格结构"""
        self.log_and_display("开始解析Markdown表格结构")
        
        # 存储表格信息的字典
        table_structure = {}
        
        # 按表格分割
        table_blocks = markdown_text.split('* **')
        
        for block in table_blocks[1:]:  # 跳过第一个空元素
            # 分割表格名称和字段
            lines = block.split('\n')
            table_name = lines[0].strip()
            
            # 提取字段
            fields = []
            for line in lines[1:]:
                line = line.strip()
                if line.startswith('* '):
                    # 移除 '* ' 前缀
                    fields.append(line[2:].strip())
            
            self.log_and_display(f"表格: {table_name}")
            self.log_and_display(f"字段: {fields}")
            
            # 存储表格结构
            table_structure[table_name] = fields
        
        self.log_and_display(f"解析完成,总表格数: {len(table_structure)}")
        return table_structure
    
    def on_convert(self, event):
        """转换Markdown结构到Excel"""
        # 清空之前的日志
        self.log_text.Clear()
        
        markdown_text = self.input_text.GetValue()
        
        if not markdown_text.strip():
            wx.MandroidessageBox('请输入Markdown表格结构', '错误', wx.OK | wx.ICON_ERROR)
            return
        
        try:
            # 解析Markdown结构
            table_structure = self.parse_markdown_structure(markdown_text)
            
            # 创建工作簿
            wb = openpyxl.Workbook()
            
            # 为每个表格创建sheet
            first_sheet = True
            for table_name, fields in table_structure.items():
                self.log_and_display(f"创建sheet: {table_name}")
                
                if first_sheet:
                    # 重命名第一个sheet
                    ws = wb.active
                    ws.title = table_name.split(' ')[0][:31]  # Excel sheet名称长度限制
                    first_sheet = False
                else:
                    ws = wb.create_sheet(title=table_name.split(' ')[0][:31])
                
                # 写入表头
                for col, field in enumerate(fields, start=1):
                    ws.cell(row=1, column=col, value=field)
                
                # 添加一个示例行(可选)
                for col, field in enumerate(fields, start=1):
                    ws.cell(row=2, column=col, value=f"示例{field}")
            
            # 保存文件
            save_dialog =China编程 wx.FileDialog(
                self, 
                "保存Excel文件", 
                wildcard="Excel文件 (*.xlsx)|*.xlsx", 
                style=wx.FD_SAVE | wx.FD_OVERWRITE_PROMPT
            )
            
            if save_dialog.ShowModal() == wx.ID_OK:
                filename = save_dialog.GetPath()
                wb.save(filename)
                self.log_and_display(f'Excel文件已保存:{filename}')
                wx.MessageBox(f'Excel文件已保存:{filename}', '成功', wx.OK | wx.ICON_INFORMATION)
            
            save_dialog.Destroy()
        
        except Exception as e:
            error_msg = f'转换出错:{str(e)}'
            self.log_and_display(error_msg)
            wx.MessageBox(error_msg, '错误', wx.OK | wx.ICON_ERROR)
    
    def on_exit(self, event):
        """退出应用程序"""
        self.Close(True)

def main():
    app = wx.App()
    frame = MarkdownToExcelChina编程App()
    frame.Show()
    app.MainLoop()

if __name__ == '__main__':
    main()

2. 项目概述

本项目提供一个图形界面,用户可以输入 Markdown 格式的表格结构,程序解析后生成 Excel 文件。该应用具备以下功能:

  • 支持 Markdown 格式的表格结构解析。
  • 生成 Excel 文件,每个表格对应一个工作表。
  • 记录日志,方便调试。
  • 提供 GUI 界面,用户体验友好。

3. 代码解析

3.1 依赖库

import wx
import re
import openpyxl
import logging

wx 用于创建 GUI 界面。

re 用于正则表达式解析 Markdown 表格。

openpyxl 用于创建 Excel 文件。

logging 记录调试信息。

3.2 GUI 设计

class MarkdownToExcelApp(wx.Frame):
    def __init__(self):
        super().__init__(parent=None, title="利用Python开发Markdown表格结构转换为Excel工具", size=(800, 600))

wx.Frame 创建主窗口,标题为“Markdown 转 Excel”。

设置窗口大小为 800x600。

# 配置日志
logging.basicConfig(level=logging.DEBUG, 
                    format='%(asctime)s - %(levelname)s - %(message)s',
                    filename='markdown_to_excel_debug.log',
                    filemode='w')

记录日志到 markdown_to_excel_debug.log,用于调试。

# 创建面板
panel = wx.Panel(self)
# 创建垂直布局
main_sizer = wx.BoxSizer(wx.VERTICAL)

wx.Panel 是 GUI 的容器。

wx.BoxSizer(wx.VERTICAL) 采用垂直布局管理组件。

3.3 解析 Markdown 结构

def parse_markdown_structure(self, markdown_text):
    self.log_and_display("开始解析Markdown表格结构")
    table_structure = {}
    table_blocks = markdown_text.split('* **')
    for block in table_blocks[1:]:
        lines = block.split('\n')
        table_name = lines[0].strip()
        fields = [line[2:].strip() for line in lines[1:] if line.startswith('* ')]
        self.log_and_display(f"表格: {table_name}")
        self.log_and_display(f"字段: {fields}")
        table_structure[table_name] = fields
    self.log_and_display(f"解析完成,总表格数: {len(table_structure)}")
    return table_structure

split('* **') 将 Markdown 文本按表格名称分割。

逐行解析字段。

记录日志信息。

3.4 生成 Excel

def on_convert(self, event):
    markdown_text = self.input_text.GetValue()
    if not markdown_text.strip():
        wx.MessageBox('请输入Markdown表格结构', '错误', wx.OK | wx.ICON_ERROR)
        return
    try:
        table_structure = self.parse_markdown_structure(markdown_text)
        wb = openpyxl.Workbook()
        first_sheet = True
        for table_name, fields in table_structure.items():
            ws = wb.active if first_sheet else wb.create_sheet(title=table_name.split(' ')[0][:31])
            first_sheet = False
            for col, field in enumerate(fields, start=1):
                ws.cell(row=1, column=col, value=field)
                ws.cell(row=2, column=col, value=f"示例{field}")
        save_dialog = wx.FileDialog(self, "保存Excel文件", wildcard="Excel文件 (*.xlsx)|*.xlsx", style=wx.FD_SAVE | wx.FD_OVERWRITE_PROMPT)
        if save_dialog.ShowModal() == wx.ID_OK:
            filename = save_dialog.GetPath()
            wb.save(filename)
            self.log_and_display(f'Excel文件已保存:{filename}')
            wx.MessageBox(f'Excel文件已保存:{filename}', '成功', wx.OK | wx.ICON_INFORMATION)
    except Exception as e:
        self.log_and_display(f'转换出错:{str(e)}')
        wx.MessageBox(f'转换出错:{str(e)}', '错误', wx.OK | wx.ICON_ERROR)

openpyxl.Workbook() 创建 Excel 文件。

create_sheet() 创建多个表格,每个表格对应一个工作表。

wx.FileDialog 让用户选择文件保存路径。

logging 记录转换过程。

3.5 退出应用

def on_exit(self, event):
    self.Close(True)

关闭应用。

4. 运行程序

def main():
    app = wx.App()
    frame = MarkdownToExcelApp()
    frame.Show()
    app.MainLoop()

if __name__ == '__main__':
    main()

启动 wxPython GUI。

5. 总结

本项目通过 wxPython 构建用户界面,并结合 openpyxl 解析 Markdown 表格并生成 Excel 文件。它适用于希望从 Markdown 结构化数据导出 Excel 的用户,简化了手动整理表格的过程。

你可以进一步优化该项目,如:

增加 Markdown 语法校验。

允许用户调整 Excel 文件格式。

增加数据预览功能。

6.运行结果

利用Python开发Markdown表格结构转换为Excel工具

利用Python开发Markdown表格结构转换为Excel工具

以上就是利用Python开发Markdown表格结构转换为Excel工具的详细内容,更多关于Python Markdown转Excel的资料请关注编程China编程(www.chinasem.cn)其它相关文章!

这篇关于利用Python开发Markdown表格结构转换为Excel工具的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

一文全面详解Python变量作用域

《一文全面详解Python变量作用域》变量作用域是Python中非常重要的概念,它决定了在哪里可以访问变量,下面我将用通俗易懂的方式,结合代码示例和图表,带你全面了解Python变量作用域,需要的朋友... 目录一、什么是变量作用域?二、python的四种作用域作用域查找顺序图示三、各作用域详解1. 局部作

Python主动抛出异常的各种用法和场景分析

《Python主动抛出异常的各种用法和场景分析》在Python中,我们不仅可以捕获和处理异常,还可以主动抛出异常,也就是以类的方式自定义错误的类型和提示信息,这在编程中非常有用,下面我将详细解释主动抛... 目录一、为什么要主动抛出异常?二、基本语法:raise关键字基本示例三、raise的多种用法1. 抛

Python基于微信OCR引擎实现高效图片文字识别

《Python基于微信OCR引擎实现高效图片文字识别》这篇文章主要为大家详细介绍了一款基于微信OCR引擎的图片文字识别桌面应用开发全过程,可以实现从图片拖拽识别到文字提取,感兴趣的小伙伴可以跟随小编一... 目录一、项目概述1.1 开发背景1.2 技术选型1.3 核心优势二、功能详解2.1 核心功能模块2.

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

基于Python构建一个高效词汇表

《基于Python构建一个高效词汇表》在自然语言处理(NLP)领域,构建高效的词汇表是文本预处理的关键步骤,本文将解析一个使用Python实现的n-gram词频统计工具,感兴趣的可以了解下... 目录一、项目背景与目标1.1 技术需求1.2 核心技术栈二、核心代码解析2.1 数据处理函数2.2 数据处理流程

C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式

《C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式》Markdown凭借简洁的语法、优良的可读性,以及对版本控制系统的高度兼容性,逐渐成为最受欢迎的文档格式... 目录为什么要将文档转换为 Markdown 格式使用工具将 Word 文档转换为 Markdown(.

CnPlugin是PL/SQL Developer工具插件使用教程

《CnPlugin是PL/SQLDeveloper工具插件使用教程》:本文主要介绍CnPlugin是PL/SQLDeveloper工具插件使用教程,具有很好的参考价值,希望对大家有所帮助,如有错... 目录PL/SQL Developer工具插件使用安装拷贝文件配置总结PL/SQL Developer工具插