在数据管理和文档编写过程中,我们经常使用 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 文件格式。
- 增加数据预览功能。
运行结果