python - excel 设置样式

news2024/11/15 13:21:56

文章目录

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

前言

  如果您觉得有用的话,记得给博主点个赞,评论,收藏一键三连啊,写作不易啊^ _ ^。
  而且听说点赞的人每天的运气都不会太差,实在白嫖的话,那欢迎常来啊!!!


python - excel 设置样式

1. 准备

准备一个无样式的excel
在这里插入图片描述
在这里插入图片描述

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

2. 示例

2.1. 给单元格设置样式"等线"、大小为24磅、斜体、红色颜色和粗体
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磅、斜体、红色颜色和粗体
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. 给第三行数据设置垂直居中和水平居中
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
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
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
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单元格应用边框样式
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
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}")

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1085044.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

第十四章总结

一.lambda表达式 1.lambda表达式简介 lambda表达式不能独立执行,因此必须实现函数式接口,并且会返回一个函数式接口的对象。 语法: ()->结果表达式 参数->结果表达式 (参数1,参数2,...,参数…

Docker部署gitlab_ce(避坑版---社区版)

1 下载docker 2 下载gitlab镜像 3 运行 4 进入容器内部修改 5 在浏览器里访问 6 修改root密码(如果忘记请修改) 1 下载docker # 安装依赖 yum install -y yum-utils device-mapper-persistent-data lvm2# 设置yum源 yum-config-manager --add-repo https…

开放式耳机选择什么品牌?六款口碑好爆的开放式耳机盘点

喜欢把户外运动纳入生活计划的朋友,都是懂得享受生活的乖仔,那么大家也需要一副既匹配运动场景又可保护听力,同时还有好音质相伴的耳机一起出发运动吧?在各商家卯足劲儿推出创新产品、伙计们也都挑得眼花缭乱的时候,我…

Linux基础指令(一)

📙作者简介: 清水加冰,目前大二在读,正在学习C/C、Python、操作系统、数据库等。 📘相关专栏:C语言初阶、C语言进阶、C语言刷题训练营、数据结构刷题训练营、有感兴趣的可以看一看。 欢迎点赞 &#x1f44d…

进来了解实现官网搜索引擎的三种方法

做网站的目的是对自己的品牌进行推广,让越来越多的人知道自己的产品,但是如果只是做了一个网站放着,然后等着生意找上门来那是不可能的。在当今数字时代,实现官网搜索引擎对于提升用户体验和推动整体性能至关重要。搜索引擎可以帮…

echarts画电压线

ChartLibhttp://chartlib.datains.cn/detail?idx0R9f3tOqMExamples - Apache EChartsApache ECharts,一款基于JavaScript的数据可视化图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表。https://echarts.ap…

【二甲医院his系统源码】医疗卫生信息化大数据平台源码

基于云计算技术的SaaS服务的医院信息系统源码 云HIS系统有效实现医疗数据共享与交换,解决数据重复采集及信息孤岛等问题。重构管理服务流程,重建统一的信息架构体系,重造病人服务环境,向不同类型的医疗机构提供SaaS化HIS服务解决…

VNC:Timed out waiting for a response from the computer

VNC的服务端使用的是TigerVNC,客户端使用的是RealVNC TigerVNC按其他博客配好后,防火墙ip什么的都配了,vnc客户端怎么连都是超时。 这里建议大家可以尝试一下重启服务器。我的是CentOS的 shutdown -r now 配了2天,最后服务器重启…

Docker 的数据管理和网络通信

目录 Docker 的数据管理 管理 Docker 容器中数据的方式 端口映射 容器互联(使用centos镜像) Docker 镜像的创建 Dockerfile 操作常用的指令 编写 Dockerfile 时格式 Dockerfile 案例 Docker 的数据管理 管理 Docker 容器中数据的方式 管理 Doc…

第一个 Python 程序

三、第一个 Python 程序 好了,说了那么多,现在我们可以来写一下第一个 Python 程序了。 一开始写 Python 程序,个人不太建议用专门的工具来写,不方便熟悉语法,所以这里我先用 Sublime Text 来写,后期可以…

Commonjs与ES Module

commonjs 1 commonjs 实现原理 commonjs每个模块文件上存在 module,exports,require三个变量,然而这三个变量是没有被定义的,但是我们可以在 Commonjs 规范下每一个 js 模块上直接使用它们。在 nodejs 中还存在 __filename 和 __dirname 变…

信创之国产浪潮电脑+统信UOS操作系统体验4:visual studio code中怎么显示中文

☞ ░ 前往老猿Python博客 ░ https://blog.csdn.net/LaoYuanPython 一、引言 今天在vscode中打开以前的一段C代码,其中的中文显示为乱码,如图所示: 而在统信文本编辑器打开是正常的,打开所有菜单,没有找到相关配置…

物联网AI MicroPython传感器学习 之 CCS811空气质量检测传感器

学物联网,来万物简单IoT物联网!! 一、产品简介 通过CCS811传感器模块可以测量环境中TVOC(总挥发性有机物质)浓度和eCO2(二氧化碳)浓度,作为衡量空气质量(IAQ)的指标。 引脚定义 VCC:3.3VGND&…

选择适合你的知识付费小程序平台

在建立知识付费小程序之前,选择一个适合你需求的平台是至关重要的。本文将探讨几个知识付费小程序平台,并提供代码示例,帮助你了解如何在这些平台上开始搭建自己的知识付费应用。 1. 平台选择:WeChat 小程序 微信小程序是一个强…

scala代码连接华为云dws(gaussDB 200)数据库,适用于本地jar包引入maven库(gsjdbc200.jar)

scala代码连接华为云dws(gaussDB 200)数据库,适用于所有本地jar包引入maven库。 我们本地jar包通常只有一个jar包,没有pom等其他maven引入文件,在非内网等环境中,经常使用mvn install失败导致无法编译jar包到maven中&a…

PowerManagerServcie

PowerManagerServcie(PMS) 1. 电源管理架构2.电源管理4个层次3.电源管理服务 - PowerManagerService 1. 电源管理架构 PowerManagerService是android系统电源管理的核心服务。 PowerManagerService继承自SystemService,在SystemServer的main()方法中&am…

Arbitrum Stylus 的工作原理

理解 Arbitrum 如何协调 EVM 和 WASM 的共存是至关重要的。这不仅仅是拥有两个独立的引擎;这是一种增强两者优势的协同关系。 Arbitrum 的独特架构允许 EVM 和 WASM 之间进行无缝和同步的操作,这要归功于其统一的状态、跨 VM 调用和兼容的经济模型。 用…

Go 快速开发朋友圈助力项目

1.根据业务完成不同功能数据表的设计和编写 注册功能 在models/user.go中定义结构体 验证用户名是否已存在 添加用户 package modelsimport ("gin-ranking/dao""time" )type User struct {Id int json:"id"Username string json:&…

面包屑对格林童话里的兄妹没有帮助,但对你的网站有

早上看产研周报的时候瞄到一眼「面包屑」三个字,因为是个面包脑袋,所以快速识别到了这几个字,在我的认知里,面包屑和 Bytebase 好像并不对付? 其实这里说的是面包屑导航啦,加上图是不是容易理解一点&#x…

Linux进阶-加深进程印象

进程 进程状态转换 一般来说,一个进程的开始都是从其父进程调用fork()函数开始,所以在系统一上电运行时,init进程就开始工作,在系统运行过程中,会不断启动新的进程(要么由init进程启动,要么由被…