编程小白的自学笔记十六(python办公自动化操作EXCEL表格)

简介: 编程小白的自学笔记十六(python办公自动化操作EXCEL表格)

前言

前面我们学了对表格还有列的增、删、改、查,今天我们再学习一些新的内容。


一、表格冻结

什么是表格冻结:表格冻结是指在Excel中,将指定的行或列固定不动,以便在滚动时不会移动。这样可以方便地查看和比较数据。  例如,如果您想查看第一行的数据,而不想滚动到第二行,那么您可以将第一行锁定,这样它就不会随着滚动而移动了。

在python中,我们可以使用freeze_panes来实现表格的冻结,比如说,我们一般都是第一行不动,因为第一行是标题,我们可以知道每一列是什么,特别是列特别多的时候,就显得尤为的重要。下面看代码:

import openpyxl
wb=openpyxl.load_workbook('测试0709.xlsx')
ws=wb.active
ws.freeze_panes='A2'
wb.save('测试0709.xlsx')

通过以上代码我们就成功锁定了第一行,至此我们提出几个疑问:

1、为什么是A2不是A1

你亲自操作一下EXCEL表格,你就会发现,其实你也是选中第二行,然后点冻结窗口,来实现锁定第一行功能的,而不是选中第一行。

2、那么B2可不可以

我将代码改成B2以后,发现是可以的,仍然第一行是锁定的,滚轮向下滑依然完美。

3、那么F2没有数据的可以不可以

答案也是可以的,我将代码修改之后,也是成功运行,但是同时我发现一个问题,‘A,B,F也不是没有用处的,他们是负责锁定列的,B代表锁定B前面的列,也就是说锁定了A列,F锁定了A到E列。

4、那么不写A或者2行不行

既然一个代表锁定行,一个代表锁定列,我现在只需要锁定行,那么列就不写了,只写个“2”行不行?答案是不行的,我帮你们试过了,会报错。

二、设置字体样式

无论是word还是excel,我们在日常工作中都会有一些设置字体的大小、颜色等,当然我们也可以用Python来实现这个功能。首先我们对字体的相关内容进行输出:

import openpyxl
wb=openpyxl.load_workbook('大于50的表格.xlsx')
ws=wb.active
font=ws['A1'].font
print(font.name,font.size,font.color)
wb.save('大于50的表格.xlsx')

可以看出,我们想输出字体的名字、大小和颜色,输出结果为:

Calibri 11.0 <openpyxl.styles.colors.Color object>

Parameters:

rgb=None, indexed=None, auto=None, theme=1, tint=0.0, type='theme'

字体的名字为:“Calibri”,“Calibri”是一种无衬线字体,最初发布于微软Windows Vista中,亦为微软Microsoft Office 2007套装软件的默认字体。  它是一款现代的无衬线字体,具有细微的圆角和曲线,具有真正的斜体、小写字母和多种数字集。

字体的大小为11磅,颜色就是RGB,是NONE,我估计没设置颜色就是NONE。

下面我们就要对字体进行设置了,我们先看看没有设置之前的样式:

然后我们使用代码将字体、颜色、大小、倾斜全部替换掉

import openpyxl
from openpyxl.styles import Font
wb=openpyxl.load_workbook('大于50的表格.xlsx')
ws=wb.active
ws['A1'].font=Font(name='黑体',size=30,bold=True,italic=True,color='ff0000')
wb.save('大于50的表格.xlsx')

运行后,我们看结果

是成功的,我们在详细解读下代码,只要把Font类说清楚,就清楚了。

`Font`是openpyxl库中的一个类,用于设置单元格的字体属性。它有以下属性:

- `name`:字体名称,如Arial、Calibri等。

- `size`:字体大小,整数类型。

- `bold`:是否加粗,布尔类型。

- `italic`:是否斜体,布尔类型。

- `underline`:是否下划线,布尔类型。

- `color`:字体颜色,可以是十六进制颜色代码或RGB元组。

- `scheme`:字体方案,如major、minor等。

- `family`:字体家族,如sans-serif、serif等。

修改之后我们再使用输出代码输出下字体属性看一看。输出结果为:

黑体 30.0 <openpyxl.styles.colors.Color object>

Parameters:

rgb='00ff0000', indexed=None, auto=None, theme=None, tint=0.0, type='rgb'

能显示的地方显示确实已经修改了。

三、设置对齐方式

同上,导入对齐方式的库,使用起来和字体一样,在这里就不用代码赘述了,直接介绍下相关库。

我们要使用from openpyxl.styles import Alignment  导入库

`Alignment`是openpyxl库中的一个类,用于设置单元格的对齐方式。它有以下属性:

- `horizontal`:水平对齐方式,可以是`left`、`center`或`right`。

- `vertical`:垂直对齐方式,可以是`top`、`center`或`bottom`。

- `textRotation`:文本旋转角度,整数类型。

- `wrapText`:是否自动换行,布尔类型。

- `shrinkToFit`:是否自动缩小单元格以适应内容,布尔类型。

- `indent`:缩进距离,整数类型。

- `relativeIndent`:相对缩进距离,整数类型。

- `justifyLastLine`:是否对最后一行进行对齐,布尔类型。

- `readingOrder`:数字顺序,整数类型。

四、设置边框

设置边框有点复杂,需要导入两个类。

python
from openpyxl import Workbook
from openpyxl.styles import Border, Side
# 创建工作簿和工作表
wb = Workbook()
ws = wb.active
# 设置单元格边框样式
border = Border(left=Side(style='thin', color='000000'),
                right=Side(style='thin', color='000000'),
                top=Side(style='thin', color='000000'),
                bottom=Side(style='thin', color='000000'))
# 设置单元格边框颜色
for row in ws.iter_rows():
    for cell in row:
        cell.border = border
# 保存工作簿
wb.save('example.xlsx')

在这个例子中,我们首先导入了openpyxl库和Border、Side类。然后,我们创建了一个名为example.xlsx的Excel文件,并创建了一个名为ws的工作表。接下来,我们使用Border和Side类来定义单元格边框样式和颜色。最后,我们使用iter_rows函数遍历所有单元格,并将单元格边框应用到每个单元格上。最终,我们将工作簿保存到硬盘上。

 

相关文章
|
2月前
|
人工智能 数据可视化 数据挖掘
探索Python编程:从基础到高级
在这篇文章中,我们将一起深入探索Python编程的世界。无论你是初学者还是有经验的程序员,都可以从中获得新的知识和技能。我们将从Python的基础语法开始,然后逐步过渡到更复杂的主题,如面向对象编程、异常处理和模块使用。最后,我们将通过一些实际的代码示例,来展示如何应用这些知识解决实际问题。让我们一起开启Python编程的旅程吧!
|
2月前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
2月前
|
Unix Linux 程序员
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
126 80
|
23天前
|
存储 缓存 Java
Python高性能编程:五种核心优化技术的原理与Python代码
Python在高性能应用场景中常因执行速度不及C、C++等编译型语言而受质疑,但通过合理利用标准库的优化特性,如`__slots__`机制、列表推导式、`@lru_cache`装饰器和生成器等,可以显著提升代码效率。本文详细介绍了这些实用的性能优化技术,帮助开发者在不牺牲代码质量的前提下提高程序性能。实验数据表明,这些优化方法能在内存使用和计算效率方面带来显著改进,适用于大规模数据处理、递归计算等场景。
58 5
Python高性能编程:五种核心优化技术的原理与Python代码
|
2月前
|
人工智能 自然语言处理 JavaScript
Univer:开源全栈 AI 办公工具,支持 Word、Excel、PPT 等文档处理和多人实时协作
Univer 是一款开源的 AI 办公工具,支持 Word、Excel 等文档处理的全栈解决方案。它具有强大的功能、高度的可扩展性和跨平台兼容性,适用于个人和企业用户,能够显著提高工作效率。
182 8
Univer:开源全栈 AI 办公工具,支持 Word、Excel、PPT 等文档处理和多人实时协作
|
2月前
|
Python
[oeasy]python055_python编程_容易出现的问题_函数名的重新赋值_print_int
本文介绍了Python编程中容易出现的问题,特别是函数名、类名和模块名的重新赋值。通过具体示例展示了将内建函数(如`print`、`int`、`max`)或模块名(如`os`)重新赋值为其他类型后,会导致原有功能失效。例如,将`print`赋值为整数后,无法再用其输出内容;将`int`赋值为整数后,无法再进行类型转换。重新赋值后,这些名称失去了原有的功能,可能导致程序错误。总结指出,已有的函数名、类名和模块名不适合覆盖赋新值,否则会失去原有功能。如果需要使用类似的变量名,建议采用其他命名方式以避免冲突。
52 14
|
2月前
|
分布式计算 大数据 数据处理
技术评测:MaxCompute MaxFrame——阿里云自研分布式计算框架的Python编程接口
随着大数据和人工智能技术的发展,数据处理的需求日益增长。阿里云推出的MaxCompute MaxFrame(简称“MaxFrame”)是一个专为Python开发者设计的分布式计算框架,它不仅支持Python编程接口,还能直接利用MaxCompute的云原生大数据计算资源和服务。本文将通过一系列最佳实践测评,探讨MaxFrame在分布式Pandas处理以及大语言模型数据处理场景中的表现,并分析其在实际工作中的应用潜力。
116 2
|
2月前
|
小程序 开发者 Python
探索Python编程:从基础到实战
本文将引导你走进Python编程的世界,从基础语法开始,逐步深入到实战项目。我们将一起探讨如何在编程中发挥创意,解决问题,并分享一些实用的技巧和心得。无论你是编程新手还是有一定经验的开发者,这篇文章都将为你提供有价值的参考。让我们一起开启Python编程的探索之旅吧!
65 10
|
2月前
|
IDE 程序员 开发工具
Python编程入门:打造你的第一个程序
迈出编程的第一步,就像在未知的海洋中航行。本文是你启航的指南针,带你了解Python这门语言的魅力所在,并手把手教你构建第一个属于自己的程序。从安装环境到编写代码,我们将一步步走过这段旅程。准备好了吗?让我们开始吧!
|
2月前
|
关系型数据库 开发者 Python
Python编程中的面向对象设计原则####
在本文中,我们将探讨Python编程中的面向对象设计原则。面向对象编程(OOP)是一种通过使用“对象”和“类”的概念来组织代码的方法。我们将介绍SOLID原则,包括单一职责原则、开放/封闭原则、里氏替换原则、接口隔离原则和依赖倒置原则。这些原则有助于提高代码的可读性、可维护性和可扩展性。 ####

热门文章

最新文章

推荐镜像

更多