将 Markdown 表格结构转换为Excel 文件

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

C:\pythoncode\new\MarkdownToExcel.py

所有代码

python 复制代码
import wx
import re
import openpyxl
import logging

class MarkdownToExcelApp(wx.Frame):
    def __init__(self):
        super().__init__(parent=None, title='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)
        
        # 日志文本框
        self.log_text = wx.TextCtrl(panel, style=wx.TE_MULTILINE | wx.TE_READONLY)
        main_sizer.Add(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.MessageBox('请输入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 = 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 = MarkdownToExcelApp()
    frame.Show()
    app.MainLoop()

if __name__ == '__main__':
    main()

1. 项目概述

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

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

2. 代码解析

2.1 依赖库
python 复制代码
import wx
import re
import openpyxl
import logging
  • wx 用于创建 GUI 界面。
  • re 用于正则表达式解析 Markdown 表格。
  • openpyxl 用于创建 Excel 文件。
  • logging 记录调试信息。
2.2 GUI 设计
python 复制代码
class MarkdownToExcelApp(wx.Frame):
    def __init__(self):
        super().__init__(parent=None, title='Markdown 转 Excel', size=(800, 600))
  • wx.Frame 创建主窗口,标题为"Markdown 转 Excel"。
  • 设置窗口大小为 800x600。
python 复制代码
# 配置日志
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,用于调试。
python 复制代码
# 创建面板
panel = wx.Panel(self)
# 创建垂直布局
main_sizer = wx.BoxSizer(wx.VERTICAL)
  • wx.Panel 是 GUI 的容器。
  • wx.BoxSizer(wx.VERTICAL) 采用垂直布局管理组件。
2.3 解析 Markdown 结构
python 复制代码
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 文本按表格名称分割。
  • 逐行解析字段。
  • 记录日志信息。
2.4 生成 Excel
python 复制代码
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 记录转换过程。
2.5 退出应用
python 复制代码
def on_exit(self, event):
    self.Close(True)
  • 关闭应用。

3. 运行程序

python 复制代码
def main():
    app = wx.App()
    frame = MarkdownToExcelApp()
    frame.Show()
    app.MainLoop()

if __name__ == '__main__':
    main()
  • 启动 wxPython GUI。

4. 总结

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

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

  • 增加 Markdown 语法校验。
  • 允许用户调整 Excel 文件格式。
  • 增加数据预览功能。

运行结果


相关推荐
清水白石008几秒前
《用 Python 单例模式打造稳定高效的数据库连接管理器》
数据库·python·单例模式
啊阿狸不会拉杆2 分钟前
《数字图像处理》第7章:小波变换和其他图像变换
图像处理·人工智能·python·算法·机器学习·计算机视觉·数字图像处理
梅孔立9 分钟前
【实用教程】python 批量解析 EML 邮件文件 存成txt ,可以利用 AI 辅助快速生成年终总结
开发语言·python
臼犀24 分钟前
孩子,那不是说明书,那是祈祷文
人工智能·程序员·markdown
BoBoZz1930 分钟前
ExtractSelectionUsingCells选择和提取三维模型中的特定单元(Cell)
python·vtk·图形渲染·图形处理
韩立学长34 分钟前
【开题答辩实录分享】以《跳蚤市场二手物品交易推荐平台》为例进行选题答辩实录分享
python·django
yaoxin52112337 分钟前
273. Java Stream API - Stream 中的中间操作:Mapping 操作详解
java·开发语言·python
java1234_小锋37 分钟前
[免费]基于Python的Flask+Vue物业管理系统【论文+源码+SQL脚本】
后端·python·flask·物业管理
free-elcmacom37 分钟前
机器学习高阶教程<5>当机器学习遇上运筹学:破解商业决策的“终极难题”
人工智能·python·机器学习
技术小甜甜38 分钟前
[Python实战] 告别浏览器驱动烦恼:用 Playwright 优雅实现网页自动化
开发语言·python·自动化