Python实战:Excel中文转拼音工具开发教程

news/2025/2/22 23:28:34

在日常办公中,我们经常需要处理Excel文件,有时候需要将中文转换为拼音缩写以方便检索和使用。今天我将分享一个使用Python开发的小工具,它可以自动将Excel文件中指定列的中文转换为拼音缩写
C:\pythoncode\new\ConvertExcelcontentToPinyin.py

开发环境准备

首先,我们需要安装以下Python库:

pip install wxPython    # 用于创建图形界面
pip install openpyxl    # 用于处理Excel文件
pip install pypinyin    # 用于中文转拼音

核心功能设计

我们的工具主要实现以下功能:

  1. 图形界面选择Excel文件
  2. 自动定位"项目名称"和"部门"列
  3. 中文转换为拼音大写缩写
  4. 生成新的Excel文件
  5. 显示处理结果

代码实现

全部代码

python">import wx
import openpyxl
from pypinyin import pinyin, Style
import os

class MainFrame(wx.Frame):
    def __init__(self):
        super().__init__(parent=None, title='Excel中文转拼音缩写工具', size=(500, 300))
        self.init_ui()
        
    def init_ui(self):
        panel = wx.Panel(self)
        vbox = wx.BoxSizer(wx.VERTICAL)
        
        # 创建文件选择按钮
        select_btn = wx.Button(panel, label='选择Excel文件')
        select_btn.Bind(wx.EVT_BUTTON, self.on_select)
        vbox.Add(select_btn, 0, wx.ALL | wx.CENTER, 20)
        
        # 创建状态显示文本框
        self.status_text = wx.TextCtrl(panel, style=wx.TE_MULTILINE | wx.TE_READONLY)
        vbox.Add(self.status_text, 1, wx.ALL | wx.EXPAND, 20)
        
        panel.SetSizer(vbox)
        self.Centre()
        
    def on_select(self, event):
        with wx.FileDialog(self, "选择Excel文件", wildcard="Excel files (*.xlsx)|*.xlsx",
                         style=wx.FD_OPEN | wx.FD_FILE_MUST_EXIST) as fileDialog:
            
            if fileDialog.ShowModal() == wx.ID_CANCEL:
                return
            
            pathname = fileDialog.GetPath()
            try:
                self.process_excel(pathname)
            except Exception as e:
                wx.MessageBox(f'处理文件时发生错误:{str(e)}', '错误',
                            wx.OK | wx.ICON_ERROR)

    def get_pinyin_abbr(self, chinese_str):
        """获取中文的拼音缩写"""
        if not chinese_str or not isinstance(chinese_str, str):
            return chinese_str
            
        # 获取每个字的拼音首字母
        abbr = ''
        for p in pinyin(chinese_str, style=Style.FIRST_LETTER):
            abbr += p[0].upper()
        return abbr
    
    def process_excel(self, filepath):
        """处理Excel文件"""
        self.status_text.SetValue("开始处理文件...\n")
        
        # 加载工作簿
        wb = openpyxl.load_workbook(filepath)
        ws = wb.active
        
        # 查找目标列的索引
        project_col = None
        dept_col = None
        
        for col in range(1, ws.max_column + 1):
            cell_value = ws.cell(row=2, column=col).value  # 假设第2行是标题行
            if cell_value == "项目名称":
                project_col = col
            elif cell_value == "部门":
                dept_col = col
        
        if not project_col or not dept_col:
            raise ValueError("未找到'项目名称'或'部门'列")
        
        # 转换内容
        changes = []
        for row in range(3, ws.max_row + 1):  # 从第3行开始处理
            # 处理项目名称
            project_cell = ws.cell(row=row, column=project_col)
            if project_cell.value:
                original_project = project_cell.value
                project_cell.value = self.get_pinyin_abbr(original_project)
                changes.append(f"行 {row}: 项目名称 '{original_project}' -> '{project_cell.value}'")
            
            # 处理部门
            dept_cell = ws.cell(row=row, column=dept_col)
            if dept_cell.value:
                original_dept = dept_cell.value
                dept_cell.value = self.get_pinyin_abbr(original_dept)
                changes.append(f"行 {row}: 部门 '{original_dept}' -> '{dept_cell.value}'")
        
        # 生成新文件名
        file_dir = os.path.dirname(filepath)
        file_name = os.path.basename(filepath)
        new_file_name = f"pinyin_{file_name}"
        new_filepath = os.path.join(file_dir, new_file_name)
        
        # 保存新文件
        wb.save(new_filepath)
        
        # 更新状态
        status_msg = "\n".join(changes)
        self.status_text.AppendText(f"\n转换完成!更改详情:\n{status_msg}\n\n新文件已保存为:{new_filepath}")

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

if __name__ == '__main__':
    main()

1. 创建图形界面

首先,我们使用wxPython创建一个简单的图形界面:

python">class MainFrame(wx.Frame):
    def __init__(self):
        super().__init__(parent=None, title='Excel中文转拼音缩写工具', size=(500, 300))
        self.init_ui()
        
    def init_ui(self):
        panel = wx.Panel(self)
        vbox = wx.BoxSizer(wx.VERTICAL)
        
        # 创建文件选择按钮
        select_btn = wx.Button(panel, label='选择Excel文件')
        select_btn.Bind(wx.EVT_BUTTON, self.on_select)
        vbox.Add(select_btn, 0, wx.ALL | wx.CENTER, 20)
        
        # 创建状态显示文本框
        self.status_text = wx.TextCtrl(panel, style=wx.TE_MULTILINE | wx.TE_READONLY)
        vbox.Add(self.status_text, 1, wx.ALL | wx.EXPAND, 20)
        
        panel.SetSizer(vbox)
        self.Centre()

2. 实现文件选择功能

添加文件选择对话框和错误处理:

python">def on_select(self, event):
    with wx.FileDialog(self, "选择Excel文件", wildcard="Excel files (*.xlsx)|*.xlsx",
                      style=wx.FD_OPEN | wx.FD_FILE_MUST_EXIST) as fileDialog:
        
        if fileDialog.ShowModal() == wx.ID_CANCEL:
            return
        
        pathname = fileDialog.GetPath()
        try:
            self.process_excel(pathname)
        except Exception as e:
            wx.MessageBox(f'处理文件时发生错误:{str(e)}', '错误',
                        wx.OK | wx.ICON_ERROR)

3. 中文转拼音功能

使用pypinyin库实现中文转拼音缩写

python">def get_pinyin_abbr(self, chinese_str):
    """获取中文的拼音缩写"""
    if not chinese_str or not isinstance(chinese_str, str):
        return chinese_str
        
    # 获取每个字的拼音首字母
    abbr = ''
    for p in pinyin(chinese_str, style=Style.FIRST_LETTER):
        abbr += p[0].upper()
    return abbr

4. Excel处理核心功能

实现Excel文件的读取、处理和保存:

python">def process_excel(self, filepath):
    """处理Excel文件"""
    self.status_text.SetValue("开始处理文件...\n")
    
    # 加载工作簿
    wb = openpyxl.load_workbook(filepath)
    ws = wb.active
    
    # 查找目标列的索引
    project_col = None
    dept_col = None
    
    for col in range(1, ws.max_column + 1):
        cell_value = ws.cell(row=2, column=col).value
        if cell_value == "项目名称":
            project_col = col
        elif cell_value == "部门":
            dept_col = col
    
    # 转换内容并保存
    # ... (详细代码见完整实现)

技术要点解析

  1. wxPython使用技巧

    • 使用BoxSizer进行界面布局
    • 添加文件选择对话框
    • 实现事件绑定
  2. Excel处理技巧

    • 使用openpyxl读写Excel文件
    • 动态查找目标列
    • 保持原始格式不变
  3. 中文转拼音处理

    • 使用pypinyin库处理中文
    • 提取拼音首字母
    • 处理异常情况

使用效果

  1. 运行程序后显示简洁的操作界面
  2. 点击按钮选择Excel文件
  3. 自动处理并生成新文件
  4. 界面实时显示处理进度和结果

实际应用案例

比如有以下数据:

  • 项目名称:智能消防工程
  • 部门:消防支队

转换后变为:

  • 项目名称:ZNXFGC
  • 部门:XFZD

注意事项

  1. 确保Excel文件格式正确
  2. 表格第2行必须是标题行
  3. 从第3行开始处理数据
  4. 原文件不会被修改

未来优化方向

  1. 添加自定义列选择功能
  2. 支持更多Excel格式
  3. 添加批量处理功能
  4. 优化转换规则

运行结果

在这里插入图片描述


http://www.niftyadmin.cn/n/5862843.html

相关文章

图解MySQL【日志】——Redo Log

Redo Log(重做日志) 为什么需要 Redo Log? 1. 崩溃恢复 数据库崩溃时,系统通过 Redo Log 来恢复尚未写入磁盘的数据。Redo Log 记录了所有已提交事务的操作,系统在重启后会重做这些操作,以保证数据不会丢…

JUC并发—9.并发安全集合四

大纲 1.并发安全的数组列表CopyOnWriteArrayList 2.并发安全的链表队列ConcurrentLinkedQueue 3.并发编程中的阻塞队列概述 4.JUC的各种阻塞队列介绍 5.LinkedBlockingQueue的具体实现原理 6.基于两个队列实现的集群同步机制 4.JUC的各种阻塞队列介绍 (1)基于数组的阻塞…

Springboot 高频面试题

以下是Spring Boot的高频面试题及答案和底层原理解释: 基础概念 什么是Spring Boot,其主要特点是什么? 答案: Spring Boot本质上是一个建立在Spring框架之上的快速应用开发框架。其主要特点包括: 启动器:一…

力扣LeetCode: 2209 用地毯覆盖后的最少白色砖块

题目: 给你一个下标从 0 开始的 二进制 字符串 floor ,它表示地板上砖块的颜色。 floor[i] 0 表示地板上第 i 块砖块的颜色是 黑色 。floor[i] 1 表示地板上第 i 块砖块的颜色是 白色 。 同时给你 numCarpets 和 carpetLen 。你有 numCarpets 条 黑…

go 错误处理 error

普通错误处理 // 包路径 package mainimport ("errors""fmt" )func sqrt(f1, f2 float64) (float64, error) {if f2 < 0 {return 0, errors.New("error: f2 < 0")}return f1 / f2, nil }func sqrt1(f1, f2 float64) {if re, err : sqrt(f…

Python中的Flask深入认知搭建前端页面?

一、Flask 的介绍 1. 什么是Flask&#xff1f; Flask 是一个轻量级的 Python Web 框架&#xff0c;因其简单易用、灵活性高而广受欢迎。它适合快速开发小型应用&#xff0c;也可以通过扩展支持复杂的功能需求。可以结合 HTML、CSS 和 JavaScript 实现丰富的交互功能。 2. 核…

【C# 数据结构】队列 FIFO

目录 队列的概念FIFO (First-In, First-Out)Queue<T> 的工作原理&#xff1a;示例&#xff1a;解释&#xff1a; 小结&#xff1a; 环形队列1. **FIFO&#xff1f;**2. **环形缓冲队列如何实现FIFO&#xff1f;**关键概念&#xff1a; 3. **环形缓冲队列的工作过程**假设…

YOLOv11-ultralytics-8.3.67部分代码阅读笔记-split_dota.py

split_dota.py ultralytics\data\split_dota.py 目录 split_dota.py 1.所需的库和模块 2.def bbox_iof(polygon1, bbox2, eps1e-6): 3.def load_yolo_dota(data_root, split"train"): 4.def get_windows(im_size, crop_sizes(1024,), gaps(200,), im_rate_t…