python - excel 设置样式

文章目录

  • 前言
    • [python - excel 设置样式](#python - excel 设置样式)
      • [1. 准备](#1. 准备)
      • [2. 示例](#2. 示例)
        • [2.1. 给单元格设置样式"等线"、大小为24磅、斜体、红色颜色和粗体](#2.1. 给单元格设置样式"等线"、大小为24磅、斜体、红色颜色和粗体)
        • [2.2. 给第二行设置样式"宋体"、大小为16磅、斜体、红色颜色和粗体](#2.2. 给第二行设置样式"宋体"、大小为16磅、斜体、红色颜色和粗体)
        • [2.3. 给第三行数据设置垂直居中和水平居中](#2.3. 给第三行数据设置垂直居中和水平居中)
        • [2.4. 给第四行设置行高为30](#2.4. 给第四行设置行高为30)
        • [2.5. 给第五行设置列宽为15](#2.5. 给第五行设置列宽为15)
        • [2.6. 给A列设置列宽为 30](#2.6. 给A列设置列宽为 30)
        • [2.7. 在A1单元格应用边框样式](#2.7. 在A1单元格应用边框样式)
        • [2.8. 完整demo](#2.8. 完整demo)

前言

  如果您觉得有用的话,记得给博主点个赞,评论,收藏一键三连啊,写作不易啊^ _ ^。

  而且听说点赞的人每天的运气都不会太差,实在白嫖的话,那欢迎常来啊!!!


python - excel 设置样式

1. 准备

准备一个无样式的excel

生成demo可以看这里
python- excel 创建/写入/删sheet+花式遍历

2. 示例

2.1. 给单元格设置样式"等线"、大小为24磅、斜体、红色颜色和粗体
java 复制代码
import os

from openpyxl import load_workbook
from openpyxl.styles import Font, Alignment, Color, Border, Side


def listdir(file_path):
    paths = os.listdir(file_path)
    print(f'返回指定目录【{file_path}】下的所有文件和目录名:{os.listdir(file_path)}')
    return paths


if __name__ == '__main__':
    path = 'D:\pythonExcel'
    try:
        fileName = listdir(path)
        file_path = os.path.join(path, fileName[0])
        # 打开已有文件
        wb = load_workbook(file_path)
        # 创建一个新的sheet
        newSheet = wb["NewSheet"]
        # 设置新sheet为活动sheet
        wb.active = newSheet
        # 输入等线 24号,加粗斜体,字体颜色红色。
        # 直接使用cell的font属性,将Font对象赋值给它
        # 声明样式
        bold_italic_24_font = Font(name='等线', size=24, italic=True, color=Color(rgb="FF0000"), bold=True)

        # 给单元格设置样式
        newSheet['A1'].font = bold_italic_24_font

        wb.save(file_path)

    except Exception as e:
        print(f"Exception : {e}")
2.2. 给第二行设置样式"宋体"、大小为16磅、斜体、红色颜色和粗体
python 复制代码
import os

from openpyxl import load_workbook
from openpyxl.styles import Font, Alignment, Color, Border, Side


def listdir(file_path):
    paths = os.listdir(file_path)
    print(f'返回指定目录【{file_path}】下的所有文件和目录名:{os.listdir(file_path)}')
    return paths


if __name__ == '__main__':
    path = 'D:\pythonExcel'
    try:
        fileName = listdir(path)
        file_path = os.path.join(path, fileName[0])
        # 打开已有文件
        wb = load_workbook(file_path)
        # 创建一个新的sheet
        newSheet = wb["NewSheet"]
        # 设置新sheet为活动sheet
        wb.active = newSheet
        # 输入等线 24号,加粗斜体,字体颜色红色。
        # 直接使用cell的font属性,将Font对象赋值给它
        # 声明样式
        bold_italic_16_font = Font(name='宋体', size=16, italic=True, color=Color(rgb="FF0000"), bold=True)

        # 给第二行设置样式
        for cell in newSheet[2]:
            cell.font = bold_italic_16_font

        wb.save(file_path)

    except Exception as e:
        print(f"Exception : {e}")
2.3. 给第三行数据设置垂直居中和水平居中
python 复制代码
import os

from openpyxl import load_workbook
from openpyxl.styles import Font, Alignment, Color, Border, Side


def listdir(file_path):
    paths = os.listdir(file_path)
    print(f'返回指定目录【{file_path}】下的所有文件和目录名:{os.listdir(file_path)}')
    return paths


if __name__ == '__main__':
    path = 'D:\pythonExcel'
    try:
        fileName = listdir(path)
        file_path = os.path.join(path, fileName[0])
        # 打开已有文件
        wb = load_workbook(file_path)
        # 创建一个新的sheet
        newSheet = wb["NewSheet"]
        # 设置新sheet为活动sheet
        wb.active = newSheet
        # 给第三行设置对齐方式:给第三行数据设置垂直居中和水平居中
        for cell in newSheet[3]:
            cell.alignment = Alignment(horizontal='center', vertical='center')
        wb.save(file_path)

    except Exception as e:
        print(f"Exception : {e}")
2.4. 给第四行设置行高为30
python 复制代码
import os

from openpyxl import load_workbook
from openpyxl.styles import Font, Alignment, Color, Border, Side


def listdir(file_path):
    paths = os.listdir(file_path)
    print(f'返回指定目录【{file_path}】下的所有文件和目录名:{os.listdir(file_path)}')
    return paths


if __name__ == '__main__':
    path = 'D:\pythonExcel'
    try:
        fileName = listdir(path)
        file_path = os.path.join(path, fileName[0])
        # 打开已有文件
        wb = load_workbook(file_path)
        # 创建一个新的sheet
        newSheet = wb["NewSheet"]
        # 设置新sheet为活动sheet
        wb.active = newSheet

        # 给第四行设置行高为30
        newSheet.row_dimensions[4].height = 30
        wb.save(file_path)

    except Exception as e:
        print(f"Exception : {e}")
2.5. 给第五行设置列宽为15
python 复制代码
import os

from openpyxl import load_workbook
from openpyxl.styles import Font, Alignment, Color, Border, Side


def listdir(file_path):
    paths = os.listdir(file_path)
    print(f'返回指定目录【{file_path}】下的所有文件和目录名:{os.listdir(file_path)}')
    return paths


if __name__ == '__main__':
    path = 'D:\pythonExcel'
    try:
        fileName = listdir(path)
        file_path = os.path.join(path, fileName[0])
        # 打开已有文件
        wb = load_workbook(file_path)
        # 创建一个新的sheet
        newSheet = wb["NewSheet"]
        # 设置新sheet为活动sheet
        wb.active = newSheet

        # 给第五行设置列宽为15
        for column_letter in range(1, newSheet.max_column + 1):
            if 5 == column_letter:
                # chr(64 + column_letter)用于将列号的数值转换为列字母标识符
                newSheet.column_dimensions[chr(64 + column_letter)].width = 15
    
        wb.save(file_path)

    except Exception as e:
        print(f"Exception : {e}")
2.6. 给A列设置列宽为 30
python 复制代码
import os

from openpyxl import load_workbook
from openpyxl.styles import Font, Alignment, Color, Border, Side


def listdir(file_path):
    paths = os.listdir(file_path)
    print(f'返回指定目录【{file_path}】下的所有文件和目录名:{os.listdir(file_path)}')
    return paths


if __name__ == '__main__':
    path = 'D:\pythonExcel'
    try:
        fileName = listdir(path)
        file_path = os.path.join(path, fileName[0])
        # 打开已有文件
        wb = load_workbook(file_path)
        # 创建一个新的sheet
        newSheet = wb["NewSheet"]
        # 设置新sheet为活动sheet
        wb.active = newSheet

        # 给A列设置列宽为 30
        newSheet.column_dimensions['A'].width = 30
       
        wb.save(file_path)

    except Exception as e:
        print(f"Exception : {e}")
2.7. 在A1单元格应用边框样式
python 复制代码
import os

from openpyxl import load_workbook
from openpyxl.styles import Font, Alignment, Color, Border, Side


def listdir(file_path):
    paths = os.listdir(file_path)
    print(f'返回指定目录【{file_path}】下的所有文件和目录名:{os.listdir(file_path)}')
    return paths


if __name__ == '__main__':
    path = 'D:\pythonExcel'
    try:
        fileName = listdir(path)
        file_path = os.path.join(path, fileName[0])
        # 打开已有文件
        wb = load_workbook(file_path)
        # 创建一个新的sheet
        newSheet = wb["NewSheet"]
        # 设置新sheet为活动sheet
        wb.active = newSheet
        # 创建一个Border对象来定义边框样式
        border = Border(
            left=Side(style='thin'),  # 左边框
            right=Side(style='thin'),  # 右边框
            top=Side(style='thin'),  # 上边框
            bottom=Side(style='thin')  # 下边框
        )
        # 在A1单元格应用边框样式
        newSheet['A1'].border = border
        wb.save(file_path)

    except Exception as e:
        print(f"Exception : {e}")
2.8. 完整demo
python 复制代码
import os

from openpyxl import load_workbook
from openpyxl.styles import Font, Alignment, Color, Border, Side


def listdir(file_path):
    paths = os.listdir(file_path)
    print(f'返回指定目录【{file_path}】下的所有文件和目录名:{os.listdir(file_path)}')
    return paths


if __name__ == '__main__':
    path = 'D:\pythonExcel'
    try:
        fileName = listdir(path)
        file_path = os.path.join(path, fileName[0])
        # 打开已有文件
        wb = load_workbook(file_path)
        # 创建一个新的sheet
        newSheet = wb["NewSheet"]
        # 设置新sheet为活动sheet
        wb.active = newSheet
        # 输入等线 24号,加粗斜体,字体颜色红色。
        # 直接使用cell的font属性,将Font对象赋值给它
        # 声明样式
        bold_italic_24_font = Font(name='等线', size=24, italic=True, color=Color(rgb="FF0000"), bold=True)
        bold_italic_16_font = Font(name='宋体', size=16, italic=True, color=Color(rgb="FF0000"), bold=True)
        # 创建一个Border对象来定义边框样式
        border = Border(
            left=Side(style='thin'),  # 左边框
            right=Side(style='thin'),  # 右边框
            top=Side(style='thin'),  # 上边框
            bottom=Side(style='thin')  # 下边框
        )
        # 给单元格设置样式
        newSheet['A1'].font = bold_italic_24_font
        # 给第二行设置样式
        for cell in newSheet[2]:
            cell.font = bold_italic_16_font
        # 给第三行设置对齐方式:给第三行数据设置垂直居中和水平居中
        for cell in newSheet[3]:
            cell.alignment = Alignment(horizontal='center', vertical='center')
        # 给第四行设置行高为30
        newSheet.row_dimensions[4].height = 30
        # 给第五行设置列宽为15
        for column_letter in range(1, newSheet.max_column + 1):
            if 5 == column_letter:
                # chr(64 + column_letter)用于将列号的数值转换为列字母标识符
                newSheet.column_dimensions[chr(64 + column_letter)].width = 15
        # 给A列设置列宽为 30
        newSheet.column_dimensions['A'].width = 30
        # 在A1单元格应用边框样式
        newSheet['A1'].border = border
        wb.save(file_path)

    except Exception as e:
        print(f"Exception : {e}")
相关推荐
ServBay8 小时前
9 个 Python 第三方库推荐,不用 AI 都好像多出一个团队
后端·python
用户8356290780518 小时前
如何使用 Python 添加和管理 Excel 批注(完整示例)
后端·python
用户8356290780518 小时前
使用 Python 管理 Excel 工作表:创建、复制、删除与重命名
后端·python
荣码17 小时前
LangGraph多Agent协作:3个Agent干活比1个强,但我踩了4个坑
java·python
用户8356290780511 天前
Python 操作 PDF 附件:添加、查看与管理指南
后端·python
宇宙之一粟2 天前
乐企版式文件生成平台
java·后端·python
学测绘的小杨2 天前
CompassFusion:一个从 GNSS 到 GNSS/INS 组合导航的独立工程包
python
zzzzzz3103 天前
当产品经理说这个很简单:我用Python自动化处理奇葩需求的实战指南
python·pycharm·产品经理
雪隐3 天前
个人电脑玩AI-06让5060 Ti给你打工——不光能画画,Qwen3-TTS还能学人说话,连我老板都信了!
人工智能·后端·python
兵慌码乱3 天前
面向桌面端的资产管理系统分层架构设计与核心模块实现
python·系统架构·sqlite·pyqt5·数据库设计·桌面应用开发·mvc架构