Python 基于win32com客户端实现Excel操作

测试环境

Python 3.6.2

代码实现

非多线程场景下使用

新建并保存EXCEL

import win32com.client
from win32api import RGB

def save_something_to_excel(result_file_path):
    excel_app = win32com.client.Dispatch('Excel.Application')
    excel_app.Visible = False  # 设置进程界面是否可见 False表示后台运行
    excel_app.DisplayAlerts = False # 设置是否显示警告和消息框
    book = excel_app.Workbooks.Add() # 添加Excel工作簿
    sheet = excel_app.Worksheets(1)  # 获取第一个Sheet

    sheet.name = '汇总统计' # 设置Sheet名称
    sheet.Columns.ColumnWidth = 10  # 设置所有列列宽
    sheet.Columns(1).ColumnWidth = 20 # 设置第1列列宽

    sheet.Rows.RowHeight = 15 # 设置所有行高
    sheet.Rows(1).RowHeight = 20  # 设置第一行行高

    usedRange = sheet.UsedRange  # 获取sheet的已使用范围
    rows = usedRange.Rows.Count  # 获取已使用范围的最大行数,初始值为 1
    cols = usedRange.Columns.Count  # 获取已使用范围的最大列数,初始值为 1
    print(rows, cols) # 输出 1 1

    usedRange.Rows.RowHeight = 30 # 设置已使用范围内的行高
    usedRange.Columns.ColumnWidth = 30 # 设置已使用范围内的列宽

    # do something ...
    row_index = 1
    for index, item in enumerate(['日期', '请求方法', 'URL', '调用次数']):
        # 单元格赋值 sheet.Cells(row_index, col_index).Value = 目标值 row_index, col_index 起始值为1
        sheet.Cells(row_index, index + 1).Value = item
    row_index += 1

    # do something else ...

    usedRange = sheet.UsedRange
    rows = usedRange.Rows.Count
    cols = usedRange.Columns.Count
    print(rows, cols) # 输出 1 4

    sheet.Cells(1, 2).Font.Size = 29  # 设置单元格字体大小
    sheet.Cells(1, 2).Font.Bold = True  # 字体是否加粗 True 表示加粗,False 表示不加粗
    sheet.Cells(2, 2).Font.Name = "微软雅黑" # 设置字体名称
    # sheet.Cells(2, 2).Font.Color = RGB(0, 0, 255) # 设置字体颜色 # 不起作用

    sheet2 = excel_app.Worksheets.Add()  # 添加Sheet页
    sheet2.Activate # 设置默认选中的sheet为sheet2

    sheet3 = excel_app.Worksheets.Add()
    #注意,Move操作,会将被移动的表单(本例中的sheet)设置为默认选中状态,也就是说覆盖 sheet.Activate所做的变更

    sheet.Move(sheet3, None)  # 将sheet移动到sheet3之前

    book.SaveAs(result_file_path) # 注意:结果文件路径必须是绝对路径
    book.Close() # 关闭工作簿
    excel_app.Quit() # 退出

if __name__ == '__main__':
    save_something_to_excel('D:\\codePojects\\logStatistics\\result\\result.xlsx')

了解更多API,可以查看参考连接

读取现有EXCEL

import win32com.client

def read_something_from_excel(excel_file_path):
    excel_app = win32com.client.Dispatch('Excel.Application')
    excel_app.Visible = False
    excel_app.DisplayAlerts = False
    book = excel_app.Workbooks.Open(result_file_path, False, True, None, None) # 打开工作簿
    
    # do something ...
    sheet = excel_app.Worksheets(1)
    print(sheet.name)
    print(sheet.Cells(1, 1).Value)

    book.SaveAs(result_file_path) # 注意:结果文件路径必须是绝对路径
    book.Close() # 关闭工作簿
    excel_app.Quit() # 退出

if __name__ == '__main__':
    read_something_from_excel('D:\\codePojects\\logStatistics\\result\\result.xlsx')

多线程场景下使用

import threading
import win32com.client
import pythoncom

def save_something_to_excel(result_file_path):
    pythoncom.CoInitialize()
    excel_app = win32com.client.DispatchEx('Excel.Application')
    # excel_app = win32com.client.Dispatch('Excel.Application')

    excel_app.Visible = False
    excel_app.DisplayAlerts = False
    book = excel_app.Workbooks.Add()
    sheet = excel_app.Worksheets(1)

    sheet.name = '汇总统计'
    row_index = 1
    for index, item in enumerate(['日期', '请求方法', 'URL', '调用次数']):
        sheet.Cells(row_index, index + 1).Value = item
    row_index += 1


    book.SaveAs(result_file_path)
    book.Close()
    excel_app.Quit()
    pythoncom.CoUninitialize() # 释放资源

if __name__ == '__main__':
    for i in range(3):
        file_path = 'D:\\codePojects\\logStatistics\\result\\result%s.xlsx' % i
        thread = threading.Thread(target=save_something_to_excel,
                                  args=(file_path,))
        thread.start()

说明:

  1. 如果不添加以下代码行:

    pythoncom.CoInitialize()
    

    会报错,如下:

    pywintypes.com_error: (-2147221008, '尚未调用 CoInitialize。', None, None)
    
  2. 建议使用

    excel_app = win32com.client.DispatchEx('Excel.Application')
    

    替代

    # excel_app = win32com.client.Dispatch('Excel.Application')
    

    实践发现,多线程的情况下,使用Dispatch会出现报错,原因似乎是Dispatch若发现进程已经存在的话,就不会创建新的进程。若不创建新的进程,有些操作会有冲突,可能会影响到已经打开的文件。

参考连接

https://learn.microsoft.com/zh-cn/office/vba/api/excel.font.color

https://blog.csdn.net/qq_25176745/article/details/125085819

原文链接:https://www.cnblogs.com/shouke/p/17277611.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Python 基于win32com客户端实现Excel操作 - Python技术站

(0)
上一篇 2023年4月30日
下一篇 2023年4月30日

相关文章

  • python实现挑选出来100以内的质数

    让我给你详细讲解一下“Python 实现挑选出来 100 以内的质数”的完整攻略。 确定质数的判断条件 首先,我们需要知道如何判断一个数是否是质数。质数是指只能被 1 和本身整除的正整数。那么根据质数的定义,我们可以得到以下判断质数的伪代码: for i in range(2, n): if n % i == 0: # n 可以被 i 整除,不是质数 ret…

    python 2023年6月3日
    00
  • 在Python中执行系统命令的方法示例详解

    在Python中执行系统命令的方法示例详解 1. subprocess模块 在Python中执行系统命令的主要方式之一是使用subprocess模块,它提供了一个简单的接口来调用系统命令和访问命令输出。 1.1. subprocess的使用方法 使用subprocess模块执行系统命令的基本方法是使用subprocess.run()函数。在run()函数中传…

    python 2023年5月30日
    00
  • Golang与python线程详解及简单实例

    Golang与Python线程详解及简单实例 线程概述 线程是操作系统能够进行运算调度的最小单位,它被包含在进程中,是进程中的实际运作单位。一个线程相当于一个子进程,但是它比子进程更加轻量级,线程与进程之间的切换比进程与进程之间的切换更快。现在的多核CPU能在同一时间运行多个线程,从而实现了并发。 在此之前需要先了解一下Golang和Python这两个编程语…

    python 2023年5月19日
    00
  • python正则表达式去掉数字中的逗号(python正则匹配逗号)

    以下是“Python正则表达式去掉数字中的逗号(python正则匹配逗号)”的完整攻略: 一、问题描述 在Python中,我们有时需要去掉数字中的逗号,以便进行数值计算或其他操作。本文将详细讲解如何使用正则表达式去掉数字中的逗号,以及如何在实际开发中应用。 二、解决方案 2.1 去掉数字中的逗号 在Python中,我们可以使用正则表达式来去掉数字中的逗号。具…

    python 2023年5月14日
    00
  • python 如何读、写、解析CSV文件

    在Python中,可以使用内置的csv模块来读取、写入和解析CSV文件。以下是读取、写入和解析CSV文件的详细攻略: 读取CSV文件 要读取CSV文件,可以使用csv模块的reader()函数。以下是读取CSV文件的示例: import csv with open(‘data.csv’, newline=”) as f: reader = csv.read…

    python 2023年5月14日
    00
  • 利用python实现可视化大屏

    利用Python实现可视化大屏的攻略 1、选择可视化库 Python中有很多可视化库可以用来制作可视化大屏,其中比较受欢迎的包括Matplotlib、Seaborn、Plotly等。你可以根据自己的需求选择适合的可视化库。以下是三个库的简介: Matplotlib:以Python为基础的绘图库,提供了各种绘图工具,可快速制作出静态图像。 Seaborn:是基…

    python 2023年5月19日
    00
  • 在Python中使用HTMLParser解析HTML的教程

    在Python中使用HTMLParser解析HTML的教程 HTMLParser是Python标准库中的一个模块,可以用于解析HTML文档。在本教程中,我们将介绍如何使用HTMLParser解析HTML文档,并提供两个示例。 安装 HTMLParser是Python标准库中的一部分,因此不需要安装。 解析HTML文档 以下是一个示例,演示如何使用HTMLPa…

    python 2023年5月15日
    00
  • python计算程序开始到程序结束的运行时间和程序运行的CPU时间

    要计算Python程序的运行时间,可以使用Python的内置时间模块time。具体步骤可以分为以下几步: 在代码的开始处,记录程序开始时间,例如使用time.time()函数: import time start_time = time.time() # 程序正式开始,写下需要计时的代码 在代码的结束处,记录程序结束时间,并计算程序的运行时间(单位为秒): …

    python 2023年6月2日
    00
合作推广
合作推广
分享本页
返回顶部