亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

利用Python開發(fā)Markdown表格結(jié)構(gòu)轉(zhuǎn)換為Excel工具

 更新時間:2025年03月27日 15:37:08   作者:winfredzhang  
在數(shù)據(jù)管理和文檔編寫過程中,我們經(jīng)常使用 Markdown 來記錄表格數(shù)據(jù),但它沒有Excel使用方便,所以本文將使用Python編寫一個轉(zhuǎn)換工具,希望對大家有所幫助

在數(shù)據(jù)管理和文檔編寫過程中,我們經(jīng)常使用 Markdown 來記錄表格數(shù)據(jù)。然而,Markdown 格式的表格在實際應(yīng)用中不如 Excel 方便,特別是需要進一步處理數(shù)據(jù)時。因此,我們開發(fā)了一個使用 wxPython 的 GUI 工具,將 Markdown 表格結(jié)構(gòu)轉(zhuǎn)換為 Excel 文件。

1.完整代碼

import wx
import re
import openpyxl
import logging

class MarkdownToExcelApp(wx.Frame):
    def __init__(self):
        super().__init__(parent=None, title='Markdown 轉(zhuǎn) Excel', size=(800, 600))
        
        # 配置日志
        logging.basicConfig(level=logging.DEBUG, 
                            format='%(asctime)s - %(levelname)s - %(message)s',
                            filename='markdown_to_excel_debug.log',
                            filemode='w')
        
        # 創(chuàng)建面板
        panel = wx.Panel(self)
        
        # 創(chuàng)建垂直布局
        main_sizer = wx.BoxSizer(wx.VERTICAL)
        
        # 輸入標簽
        input_label = wx.StaticText(panel, label='請輸入Markdown表格結(jié)構(gòu):')
        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)
        
        # 轉(zhuǎn)換按鈕
        convert_btn = wx.Button(panel, label='轉(zhuǎn)換為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)
        
        # 設(shè)置面板的布局
        panel.SetSizer(main_sizer)
        
        # 創(chuàng)建菜單欄
        menubar = wx.MenuBar()
        file_menu = wx.Menu()
        exit_item = file_menu.Append(wx.ID_EXIT, '退出', '退出應(yīng)用程序')
        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表格結(jié)構(gòu)"""
        self.log_and_display("開始解析Markdown表格結(jié)構(gòu)")
        
        # 存儲表格信息的字典
        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}")
            
            # 存儲表格結(jié)構(gòu)
            table_structure[table_name] = fields
        
        self.log_and_display(f"解析完成,總表格數(shù): {len(table_structure)}")
        return table_structure
    
    def on_convert(self, event):
        """轉(zhuǎn)換Markdown結(jié)構(gòu)到Excel"""
        # 清空之前的日志
        self.log_text.Clear()
        
        markdown_text = self.input_text.GetValue()
        
        if not markdown_text.strip():
            wx.MessageBox('請輸入Markdown表格結(jié)構(gòu)', '錯誤', wx.OK | wx.ICON_ERROR)
            return
        
        try:
            # 解析Markdown結(jié)構(gòu)
            table_structure = self.parse_markdown_structure(markdown_text)
            
            # 創(chuàng)建工作簿
            wb = openpyxl.Workbook()
            
            # 為每個表格創(chuàng)建sheet
            first_sheet = True
            for table_name, fields in table_structure.items():
                self.log_and_display(f"創(chuàng)建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'轉(zhuǎn)換出錯:{str(e)}'
            self.log_and_display(error_msg)
            wx.MessageBox(error_msg, '錯誤', wx.OK | wx.ICON_ERROR)
    
    def on_exit(self, event):
        """退出應(yīng)用程序"""
        self.Close(True)

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

if __name__ == '__main__':
    main()

2. 項目概述

本項目提供一個圖形界面,用戶可以輸入 Markdown 格式的表格結(jié)構(gòu),程序解析后生成 Excel 文件。該應(yīng)用具備以下功能:

  • 支持 Markdown 格式的表格結(jié)構(gòu)解析。
  • 生成 Excel 文件,每個表格對應(yīng)一個工作表。
  • 記錄日志,方便調(diào)試。
  • 提供 GUI 界面,用戶體驗友好。

3. 代碼解析

3.1 依賴庫

import wx
import re
import openpyxl
import logging

wx 用于創(chuàng)建 GUI 界面。

re 用于正則表達式解析 Markdown 表格。

openpyxl 用于創(chuàng)建 Excel 文件。

logging 記錄調(diào)試信息。

3.2 GUI 設(shè)計

class MarkdownToExcelApp(wx.Frame):
    def __init__(self):
        super().__init__(parent=None, title='Markdown 轉(zhuǎn) Excel', size=(800, 600))

wx.Frame 創(chuàng)建主窗口,標題為“Markdown 轉(zhuǎn) Excel”。

設(shè)置窗口大小為 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,用于調(diào)試。

# 創(chuàng)建面板
panel = wx.Panel(self)
# 創(chuàng)建垂直布局
main_sizer = wx.BoxSizer(wx.VERTICAL)

wx.Panel 是 GUI 的容器。

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

3.3 解析 Markdown 結(jié)構(gòu)

def parse_markdown_structure(self, markdown_text):
    self.log_and_display("開始解析Markdown表格結(jié)構(gòu)")
    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"解析完成,總表格數(shù): {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表格結(jié)構(gòu)', '錯誤', 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'轉(zhuǎn)換出錯:{str(e)}')
        wx.MessageBox(f'轉(zhuǎn)換出錯:{str(e)}', '錯誤', wx.OK | wx.ICON_ERROR)

openpyxl.Workbook() 創(chuàng)建 Excel 文件。

create_sheet() 創(chuàng)建多個表格,每個表格對應(yīng)一個工作表。

wx.FileDialog 讓用戶選擇文件保存路徑。

logging 記錄轉(zhuǎn)換過程。

3.5 退出應(yīng)用

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

關(guān)閉應(yīng)用。

4. 運行程序

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

if __name__ == '__main__':
    main()

啟動 wxPython GUI。

5. 總結(jié)

本項目通過 wxPython 構(gòu)建用戶界面,并結(jié)合 openpyxl 解析 Markdown 表格并生成 Excel 文件。它適用于希望從 Markdown 結(jié)構(gòu)化數(shù)據(jù)導出 Excel 的用戶,簡化了手動整理表格的過程。

你可以進一步優(yōu)化該項目,如:

增加 Markdown 語法校驗。

允許用戶調(diào)整 Excel 文件格式。

增加數(shù)據(jù)預(yù)覽功能。

6.運行結(jié)果

以上就是利用Python開發(fā)Markdown表格結(jié)構(gòu)轉(zhuǎn)換為Excel工具的詳細內(nèi)容,更多關(guān)于Python Markdown轉(zhuǎn)Excel的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評論